Incorrect string value: ‘\xF0\x9F\x9A\x9A\xE5\x9C...‘ for column ‘newscontent‘ at row 1

报错信息指向正文解析后存储乱码,MySQL不接受,查询后,是由于数据库的编码为utf-8,只能保存三个字符,有可能三方接口中数据有表情或者四个字节才能存储的汉字。

解决方法:

1、将数据库和表的编码设置为:utf8mb4,是utf8编码的超集,向下兼容utf8,并且能存储4字节的表情字符。

ALTER SCHEMA `db1`  DEFAULT CHARACTER SET utf8mb4 ;
ALTER TABLE `table1` 
CHARACTER SET = utf8mb4 ;

2、表字段的字符集也需要设置成utf8mb4

ALTER TABLE `table1` 
CHANGE COLUMN `newscontent` `newscontent` TEXT CHARACTER SET 'utf8mb4' NULL DEFAULT NULL ;

猜你喜欢

转载自blog.csdn.net/luobowangjing/article/details/131827544