记得去年我在往MySQL存入emoji表情 时,一直出错,无法导入。后来找到办法 -- 通过把 utf8 改成 utf8mb4 就可以了,并没有深究。
一年后,我看到一篇文章讲到emoji文字占4个字节,通常要用utf-8去接收才行,其他编码可能会出错。我突然想到去年操作MySQL把utf8改成utf8mb4的事儿。
嗯?他本身不就是utf8编码么!那我当时还改个锤子?
难道,MySQL的utf8不是真正的UTF-8编码吗??! 卧槽这。。MySQL有bug!
带着疑问查询了很多相关材料,才发现这竟然是MySQL的一个历史遗留问题~~ 我笑了,没想到这么牛B的MySQL也会有这段往事。
一、报错回顾
将emoji文字直接写入SQL中,执行 insert 语句报错;
INSERT INTO csjdemo.student (ID, NAME, SEX, AGE, CLASS, GRADE, HOBBY)
VALUES ('20', '陈哈哈 ', '男', '20', '181班', '9年级', '看片儿');
[Err] 1366 - Incorrect string value: '\xF0\x9F\x98\x93' for column 'NAME' at row 1
改了数据库编码、系统编码以及表字段的编码格式 → utf8mb4 之后,就可以了:
INSERT INTO student (ID, NAME, SEX, AGE, CLASS, GRADE, HOBBY)
VA