因为最近想要在数据库中添加emoji功能,因此需要在将数据库的编码格式从utf8改为utf8mb4
前言
- 在MySQL 5.5 之前,UTF-8编码只支持1-3个字节;
- 从MySQL 5.5开始,可以支持4个字节UTF编码 utf8mb4 ,一个字符能够支持更多的字符集,也能够支持更多表情符号
- emoji表情为4个字节
操作
查看编码格式:
show variables like '%char%';
修改my.cnf
文件参数
我的my.cnf路径在
/etc/mysql/conf.d
(网上的人说是my.cnf
文件参数,但是我的是mysql.cnf
)
修改后,文件内容如下:
[mysql]
default-character-set=utf8mb4
[client]
default-character-set=utf8mb4
[mysqld]
default-storage-engine=INNODB
character-set-server=utf8mb4
# character_set_filesystem=utf8mb4
init_connect = 'SET NAMES utf8mb4'
character-set-client-handshake = FALSE
collation-server=utf8mb4_general_ci
退出数据库并重启数据库
service mysql restart
查看编码格式
输入命令:
SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';
查询结果:
mysql> SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';
+--------------------------+--------------------+
| Variable_name | Value |
+--------------------------+--------------------+
| character_set_client | utf8mb4 |
| character_set_connection | utf8mb4 |
| character_set_database | utf8mb4 |
| character_set_filesystem | binary |
| character_set_results | utf8mb4 |
| character_set_server | utf8mb4 |
| character_set_system | utf8 |
| collation_connection | utf8mb4_general_ci |
| collation_database | utf8mb4_general_ci |
| collation_server | utf8mb4_general_ci |
+--------------------------+--------------------+
10 rows in set (0.00 sec)
结语
之所以要改编码格式,是因为今天突然看到一篇公众号文章标题为《记住:永远不要在MySQL中使用UTF-8》
文章提供了一个指南用于将现有数据库的字符编码从“utf8”转成“utf8mb4
其他资料信息:10分钟完成MySQL对emoji的支持
补充
修改完结束,我还对原来创建的数据库进行了修改。
查看表的格式:
show create table users;
修改如下:
ALTER TABLE comments CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
ALTER TABLE follows CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
ALTER TABLE posts CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
ALTER TABLE roles CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
ALTER TABLE users CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;