mysql数据库存储表情报错

mysql数据库存储表情报错,第1张

mysql数据库存储表情报错 报错信息

今天在数据库存入表情是报错

Incorrect string value: 'xF0x9Fx98x82' for column 'content' at row 1
原因:

emoj表情,是按照四个字节一个单位进行编码,而我们通常使用的utf-8编码在mysql数据库中默认是按照3个字节一个单位进行编码的,所有修改mysql数据库的编码为uft8mb4

mysql数据库的默认字符集utf8,只能存储3个字节的数据,标准的emoji表情是4个字节,所以要使用utf8mb4兼容四个字节

解决:
show variables like '%character%';
set character_set_client = utf8mb4;
set character_set_server = utf8mb4;
set character_set_connection = utf8mb4;
set character_set_database = utf8mb4;
set character_set_results = utf8mb4;
set collation_connection = utf8mb4_general_ci;
set collation_database = utf8mb4_general_ci;
set collation_server = utf8mb4_general_ci;
alter database 库名 character set utf8mb4;
ALTER TABLE 表名 CONVERT TO CHARACTER SET utf8mb4;
效果:

可以看到,在存储表情就没有问题了。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5717857.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存