mysql中如何修改collation

网友投稿 381 2023-11-24

mysql中如何修改collation

今天小编给大家分享一下mysql中如何修改collation的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

mysql中如何修改collation

方法:1、设置“my-f”文件,在mysqld下面添加“character_set_server=修改后的内容”和“collation_server=修改后的内容”;2、利用“systemctl restart mysqld”重启即可。

本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。

mysql中怎么修改collation

【问题报错】

数据库插入数据时,varchar 类型的字段插入中文数据时报错。

报错原文:

ERROR 1366 (HY000): Incorrect string value: ‘\xE8\xA5\xBF\xE5\xAE\x89’ for column ‘address’

【原因分析】通过 show full columns from user_bean;语句查看字段的collation属性,发现字段的collation属性值是latin1_swedish_ci ,说明字段默认为英语。未对汉语进行设置,所以当输入汉语时,mysql会报错为“字符串的值不正确”。

【解决方法】

1、编辑mysql的配置文件/etc/my-f,vi /etc/my-f

在 [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-f character_set_server=utf8 collation_server=utf8_general_ci systemctl restart mysqldalter table 表名 change 要修改的字段 字段名 数据类型  character set utf8 collate utf8_general_ci 约束条件;

以上就是“mysql中如何修改collation”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:年终盘点:云上争锋,谁领国产数据库之先机?
下一篇:人大金仓任永杰:打造国产数据库第一品牌
相关文章

 发表评论

暂时没有评论,来抢沙发吧~