mysql存储符号表情失败

个人博客版

今天再次记录下,前两天遇到的一个问题。mysql存储符号表情失败。
Incorrect string value: ‘\xF0\x9F\x98\x8A’ for column ‘content’ at row 1

解决问题思路

这个一看就是字符集的问题,我就去看了下,默认的数据库字符集是utf8,Mysql 中的只支持持最长三个字节的utf8字符,低版本的MySQL支持的utf8编码,最大字符长度为 3字节,如果遇到 4 字节的字符就会出现错误了。三个字节的 UTF-8 最大能编码的 Unicode 字符是 0xFFFF,也就是 Unicode
中的基本多文平面(BMP)。也就是说,任何不在基本多文平面的 Unicode字符,都无法使用MySQL原有的 utf8字符集存储。这些不在BMP中的字符包括哪些呢?最常见的就是Emoji 表情(Emoji 是一种特殊的 Unicode 编码,常见于 ios 和
android 手机上),和一些不常用的汉字,以及任何新增的 Unicode 字符等等。

MySQL在5.5.3版本之后增加了这个utf8mb4的编码,mb4就是most bytes
4的意思,专门用来兼容四字节的unicode。其实,utf8mb4是utf8的超集,理论上原来使用utf8,然后将字符集修改为utf8mb4,也不会对已有的utf8编码读取产生任何问题。当然,为了节省空间,一般情况下使用utf8也就够了。

数据库修改

[mysqld]
character-set-server=utf8mb4
[mysql]
default-character-set=utf8mb4
# 修改后重启Mysql

将已经建好的表也转换成utf8mb4

命令:alter table TABLE_NAME convert to character set utf8mb4 collate utf8mb4_bin; 
#(将TABLE_NAME替换成你的表名)

然后问题就得到了解决。
注意mysql版本,5.5.3之后才有utf8mb4字符集。

如果感觉有用,记得帮我点个赞,亲。

你可能感兴趣的:(mysql)