0


Mysql 1366 Incorrect string value:不正确的字符串值(编码格式)

文章目录

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;

在这里插入图片描述

标签: mysql 数据库 1366

本文转载自: https://blog.csdn.net/qq_34745941/article/details/134934663
版权归原作者 鱼丸丶粗面 所有, 如有侵权,请联系我们删除。

“Mysql 1366 Incorrect string value:不正确的字符串值(编码格式)”的评论:

还没有评论