加入收藏 | 设为首页 | 会员中心 | 我要投稿 财气旺网 - 财气网 (https://www.caiqiwang.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql中如何更改collation

发布时间:2022-06-11 12:40:10 所属栏目:MySql教程 来源:互联网
导读:今天小编给大家分享一下mysql中如何修改collation的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。 方法:1、设置my.cnf文件,在mys
  今天小编给大家分享一下mysql中如何修改collation的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
 
  方法:1、设置“my.cnf”文件,在mysqld下面添加“character_set_server=修改后的内容”和“collation_server=修改后的内容”;2、利用“systemctl restart mysqld”重启即可。
 
  本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。
 
  【问题报错】
 
  在数据库插入数据时,varchar 类型的字段插入中文数据时报错。
 
  报错原文:
 
  ERROR 1366 (HY000): Incorrect string value: ‘xE8xA5xBFxE5xAEx89’ for column ‘address’
 
  【原因分析】
 
  通过 show full columns from user_bean;语句查看字段的collation属性,发现字段的collation属性值是 latin1_swedish_ci ,说明字段默认为英语。未对汉语进行设置,所以当输入汉语时,mysql会报错为“字符串的值不正确”。
 
  【解决方法】
 
  1、编辑mysql的配置文件 /etc/my.cnf,vi /etc/my.cnf
 
  在 [mysqld] 下面加入两行补充
 
  character_set_server=utf8
 
  collation_server=utf8_general_ci
 
  2、重启Mysql服务 systemctl restart mysqld
 
  向数据库插入含中文的数据,成功!
 
  注意:上面步骤可以解决以后创建表时字段的collation属性的问题,但前面已经创建的表字段的collation属性值并不会发生变化。
 
  如果要改变之前已经创建好的表,怎么办?
 
  方法1:对原来的表进行修改,可以通过类似语句
 
  alter table user_bean change address address varchar(255) character set utf8 collate utf8_general_ci not null;
 
  方法2:删除原来的表,重新再建。
 
  【命令总结】
 
  show full columns from 表名
 
  vi /etc/my.cnf
 
  character_set_server=utf8
 
  collation_server=utf8_general_ci
 
  systemctl restart mysqld
 
  alter table 表名 change 要修改的字段 字段名 数据类型  character set utf8 collate utf8_general_ci 约束条件;
 
  以上就是“mysql中如何修改collation”这篇文章的所有内容,感谢各位的阅读!
 

(编辑:财气旺网 - 财气网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!