在 MySQL 中直接存储表情的时候,会出现无法插入数据的错误。
这是由于一般情况下,MySQL 的字符集是 utf8,而对于 emoji 表情的 mysql 的 utf8 字符集是不支持,需要修改设置为 utf8mb4 才行。
修改
修改数据库配置文件
,添加下面的配置,然后重启服务器:
- /etc/my.cnf
- [mysqld]
- character-set-server=utf8mb4
- collation_server=utf8mb4_unicode_ci
- init-connect="SET NAMES utf8mb4"
- [mysql]
- default-character-set=utf8mb4
然后再修改相应的数据库表的编码为 utf8mb4:
- ALTER TABLE tbl_name CONVERT TO CHARACTER SET utf8mb4;
客户端
使用不同的编程语言的时候,可能会对 utf8mb4 不支持,不能在连接字符串中指定的,此时可以在获取连接之后,执行
来解决这个问题。
- set names utf8mb4
比如,对于 ThinkPHP 框架,在配置文件中设置数据库连接字符集为 utf8mb4 之后 (
),会出现错误,提示无法使用这个字符集。
- 'DB_CHARSET'=>'utf8mb4'
此时,由于我们已经在 mysql 的配置文件中设置了
,所以直接将 ThinkPHP 配置文件中的数据库字符集设置为空 (
- init-connect="SET NAMES utf8mb4"
),则连接数据库之后,服务器会自动设置连接字符集为 utf8mb4,此时写入和读取 emoji 表情就能正常了。
- 'DB_CHARSET'=>''
MySQL 默认情况下,无法存储中文字符,其实这和 MySQL 默认无法存储表情字符是同样的原因:数据库字符编码问题。
默认情况下,MySQL 使用的字符集是 Latin,所以无法存储中文或者其他的一些字符。
如果要存储中文,可以设置 MySQL 的字符集为支持中文的字符集,比如 GBK 或者 UTF-8。一般情况下,我们设置为 UTF-8,能有更好的兼容性。
,添加下面的配置,然后重启服务器:
- /etc/my.cnf
- [mysqld]
- character-set-server=utf8
- [mysql]
- default-character-set=utf8
- ALTER TABLE tbl_name CONVERT TO CHARACTER SET utf8
结语
来源: