【MySQL】修改数据库的编码格式为utf8mb4

因为最近想要在数据库中添加emoji功能,因此需要在将数据库的编码格式从utf8改为utf8mb4

前言

  1. 在MySQL 5.5 之前,UTF-8编码只支持1-3个字节;
  2. 从MySQL 5.5开始,可以支持4个字节UTF编码 utf8mb4 ,一个字符能够支持更多的字符集,也能够支持更多表情符号
  3. 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

  • 链接如下:How to support full Unicode in MySQL databases

其他资料信息: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;

你可能感兴趣的:(MySQL)