MySQL 执行 SQL 语句报错:Incorrect string value

问题与处理策略

问题描述
  • 执行 MySQL SQL 语句,插入数据时,报如下错误
1366 - Incorrect string value: '\xE5\xB0\x8F\xE5\x9C\x9F...' for column 'nickname' at row 1
问题原因
  • 尝试在 nickname 列插入包含非 ASCII 字符 的数据(中文),但该列的字符集(Charset)或排序规则(Collation)不支持这些字符
处理策略
  1. 修改数据库的字符集,后续新建的表都会自动继承
ALTER DATABASE 【数据库名】 
CHARACTER SET utf8mb4 
COLLATE utf8mb4_unicode_ci;
  1. 但不会影响已存在的表,已有表的字符集需要单独修改
ALTER TABLE 【表名】
CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值