文章目录
1 解决办法
1.1 修改当前表的字符编码:仅对当前表有效
altertable 表名 converttocharacterset utf8mb4 collate utf8mb4_unicode_ci;-- 查看是否修改过来showcreatetable 表名;
1.2 修改数据库的字符编码:对所有表有效
-- 修改数据库的字符编码(注意:set 命令重启数据库后失效!)set character_set_database=utf8;set character_set_server=utf8;-- 修改表的字符编码(与数据库一致)ALTERTABLE 表名 CONVERTTOCHARACTERSET utf8;-- 查看是否修改过来SHOW VARIABLES LIKE'%character_set%';showcreatetable 表名;
1.3 建议:创建数据库时指定字符编码
-- 对所有表有效createdatabase 数据库名 characterset utf8mb4 collate utf8mb4_unicode_ci;
2 原因分析
- Mysql 版本默认使用的字符集不支持非
ASCII
字符的字符串 - 根据 Mysql 版本和配置,可能使用的是
latin1
字符集。这些字符集不支持Unicode
字符,因此在插入或更新数据时会出现错误
3 错误演示
-- 创建数据库(不指定字符编码)createdatabase db_demo;-- 创建测试表createtable char_test(
sno int,
sname varchar(50));-- 测试insertinto char_test(sno, sname)values(1,'张三');
4 扩展
4.1 查看 Mysql 版本
select version();
4.2 查看数据库的字符编码
SHOW VARIABLES LIKE'%character_set%';
4.3 查看表的字符编码
showcreatetable char_test2;
本文转载自: https://blog.csdn.net/qq_34745941/article/details/134934663
版权归原作者 鱼丸丶粗面 所有, 如有侵权,请联系我们删除。
版权归原作者 鱼丸丶粗面 所有, 如有侵权,请联系我们删除。