MySQL表中存Emoji报错Error 1366: Incorrect string value的解决方法

时间:2023-01-02 17:07:49

以前在创建MySQL表时,默认的编码都是utf8,没什么总是。最近在写一个手机的页面,测试时发现如果我在输入框的输入的Emoji字符,存入数据库时就会报错:

Error 1366: Incorrect string value: '\xF0\x9F\x91\xBD\xF0\x9F...' for column 'content'

Google说MySQL的utf8不是真正的UTF8,只能包含三个字节的unicode,4个字节就会报错。要解决此总是需要使用utf8mb4 这个编码。可是我把表和column的CHARSET都改成utf8mb4 后仍无法存入Emoji字符。

原来还要在my.cnf里修改下mysqld的character-set-server,把它改为utf8mb4,然后重启mysqld,就可存入Emoji字符了。

[mysqld]
character-set-server = utf8mb4

所以,建议大家以后在设计表时 default character set 最好设置为utf8mb4,因为现在Emoji字符已经很流行了,用户难免会在浏览器里输入Emoji字符。