mysql 不支持 utf16_为什么不建议在 MySQL 中使用 UTF-8?

MySQL的utf8编码不支持4字节的UTF-8字符,如emoji,导致插入错误。utf8mb4才是真正支持全范围UTF-8的编码。为避免问题,建议使用utf8mb4代替utf8。
摘要由CSDN通过智能技术生成

记得去年我在往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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值