【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

其他资料信息: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;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值