菜单 学习猿地 - LMONKEY

VIP

开通学习猿地VIP

尊享10项VIP特权 持续新增

知识通关挑战

打卡带练!告别无效练习

接私单赚外块

VIP优先接,累计金额超百万

学习猿地私房课免费学

大厂实战课仅对VIP开放

你的一对一导师

每月可免费咨询大牛30次

领取更多软件工程师实用特权

入驻
3109
1

MySQL 数据库保存 Emoji 表情及特殊符号

原创
05/13 14:22
阅读数 3108

何为 utf8mb4

  1. MySQL在5.5.3版本之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode。其实,utf8mb4是utf8的超集

解决方法:

  1. 查看编码字符集:
    • SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';
    • 如结果为下图所示,则『引起保存不了特殊符号的原因可能与本文不同,这篇文章可能解决不了您的问题』;
      MySQL 数据库保存 Emoji 表情及特殊符号
    • 如若结果中的 value 字段与上图有出入,请继续阅读本文;
  2. 修改数据库编码:
    • ALTER DATABASE :{database_name} CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;
  3. 修改数据表编码:
    • ALTER TABLE :{table_name} CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  4. 修改表字段编码为:
    • ALTER TABLE :{table_name} CHANGE column column VARCHAR(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  5. 编辑 my.ini 文件,添加或修改如下内容:
    [client]
    default-character-set = utf8mb4
    [mysql]
    default-character-set = utf8mb4
    [mysqld]
    character-set-client-handshake = FALSE
    character-set-server = utf8mb4
    collation-server = utf8mb4_unicode_ci
    init_connect='SET NAMES utf8mb4'
  6. 重启 Mysql
    • service mysqld restart
  7. 再次查看编码字符集,如果与上文图中结果一致,则大功告成~

发表评论

0/200
3109 点赞
1 评论
收藏
为你推荐 换一批