MySQL与emoji的兼容问题

本来以为我搞回英文就不会再被编码坑了,事实证明我还是太年轻了手动再见.gif

推特api抓取推文后存入mysql数据库,出现了一些空白内容,检查之后发现凡是以emoji开头的text存入数据库的时候会变为空。为了排除问题先在推特提供的控制台里试了试有问题的推文,结果发现它抓下来的内容是正常的,又在phpstorm里试了试直接打印出抓取内容,第一个符号是方块,后面的内容正常,所以觉得问题还是出在mysql上。

后来查了一下mysql从5.5开始支持utf8mb4编码,也就是可以兼容emoji。通常的utf8用三个字节来表示字符,而utf8mb4则是四个字节,前者是后者的一个子集,后者能表示更多字符。于是把数据库的编码改成了utf8mb4,尝试往数据库写入emoji表情仍为空,又纠结了一番发觉是php代码设置PDO的时候出了问题,参考MySQL5.6插入中文乱码的问题一文设置charset那一句应改为$charset='utf8mb4';

再次测试能成功插入,不过navicat里emoji还是显示为问号,不知道是navicat还是windows还是字体问题……

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 先补习一下Unicode 与 UTF-8的历史演变过程 http://www.jianshu.com/p/ab0d...
    爱蛇阅读 7,881评论 0 1
  • https://my.oschina.net/wingyiu/blog/153357 MYSQL 5.5 之前, ...
    爱蛇阅读 7,685评论 0 0
  • 1、问题:mysql 遇到某些中文插入异常最近有同学反馈了这样一个问题: 上述语句在脚本中 load 入库的时候会...
    kanasu阅读 7,841评论 1 4
  • MySQL数据库对象与应用 2.1-MySQL数据类型 库建立好之后基本不动,和我们接触最频繁的是表. 建表就是声...
    极客圈阅读 6,459评论 0 8
  • 作者:@荣裕君 2016年7月1日 —————————————————— 一个朋友评价我们, 说我们是英雄。 我非...
    荣裕君阅读 3,025评论 0 0