Mysql字符集不匹配导致insert报错 “SQL 错误 [1366] [HY000] ”解决方案

本文详细介绍了如何在MySQL中查看和修改字符集配置,包括使用SQL语句检查表和服务器的字符集,以及如何通过调整配置实现数据的正确导入和显示。

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

查看表的字符集

show full columns from 表名;

可以看到每个字段的字符都是utf8因此导入数据没问题,如果是其他可能会出现问题。

查看Mysql服务器字符集

show variables like '%character%';

说明:此配置可以正常insert,你的不能insert,可能在database这项配置为latin1,我们至少需要将database这项配置改为utf8。这项配置指建表时的默认字符。

修改配置 

set character_set_database=utf8;

建议除filesystem外所有都改为utf8,方法一样。

最后

修改配置后,需要重新建表后,新建的表使用的才会是utf8的字符集。因此重新建表,执行insert语句。

成功。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值