0
点赞
收藏
分享

微信扫一扫

mysql数据库存储表情报错

江南北 2022-01-30 阅读 72

报错信息

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

Incorrect string value: '\xF0\x9F\x98\x82' 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;

效果:

可以看到,在存储表情就没有问题了。
在这里插入图片描述在这里插入图片描述

举报

相关推荐

0 条评论