Mysql插入中文数据报错,设置默认collation

当尝试向varchar字段插入中文数据时,出现ERROR 1366 (HY000)错误,原因是字段collation为latin1_swedish_ci。解决方法包括在my.cnf中配置支持中文的collation并重启MySQL服务,或者直接修改已有表的collation属性。已创建的表可通过ALTER TABLE语句更改字段设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【问题报错】
在数据库插入数据时,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.cnfvi /etc/my.cnf

  2. 在 [mysqld] 下面加入两行补充
    character_set_server=utf8
    collation_server=utf8_general_ci

  3. 重启Mysql服务 systemctl restart mysqld

  4. 向数据库插入含中文的数据,成功!

注意:上面步骤可以解决以后创建表时字段的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 约束条件;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值