当前位置:   article > 正文

mysql数据库存储表情报错_表情保存至mysql报错

表情保存至mysql报错

报错信息

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

Incorrect string value: '\xF0\x9F\x98\x82' for column 'content' at row 1
  • 1

原因:

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

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

解决:

show variables like '%character%';
  • 1
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;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
alter database 库名 character set utf8mb4;
ALTER TABLE 表名 CONVERT TO CHARACTER SET utf8mb4;
  • 1
  • 2

效果:

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/人工智能uu/article/detail/899592
推荐阅读
相关标签
  

闽ICP备14008679号