今天在数据库存入表情是报错
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;效果:
可以看到,在存储表情就没有问题了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)