您当前的位置: 首页 >  sql

qq_34412985

暂无认证

  • 0浏览

    0关注

    1061博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

mysql 插入数据时,出现“\xF0\x9F\x8D\x80\xE5\xB0“这种情况的处理!

qq_34412985 发布时间:2021-09-09 17:18:38 ,浏览量:0

问题 Incorrect string value: ‘\xF0\x9F\x8D\x80\xE5\xB0…’ for column ‘question’ at row 1 我们知道设置数据库编码格式,表编码格式和字段编码格式的时候,一般设置为“utf-8”,这对于汉字来说足够了,在mysql中utf8占3个字节,但是对于移动端的特殊表情符号来说,三个字节是不够的,他需要四个字节。这个时候我们使用utf8就会出现‘\xF0\x9F\x8F\x80’的问题。

解决方法 1. 可以对4字节的字符进行编码存储,然后取出来的时候,再进行解码。但是这样做会使得任何使用该字符的地方都要进行编码与解码。

2. 更改数据库的编码为utf8mb4:utf8mb4编码是utf8编码的超集,兼容utf8,并且能存储4字节的表情字符。  采用utf8mb4编码的好处是:存储与获取数据的时候,不用再考虑表情字符的编码与解码问题。

需要改数据库表的编码格式,将至修改为utf8mb4. mysql版本5.5.3之前支持utf8三个字节,5.5.3之后支持utf8mb4四个字节。mysql -V 查看版本,如果版本过低,先升级。

  1. 修改mysql配置文件my.cnf(windows为my.ini)

  2. my.cnf一般在etc/mysql/my.cnf位置。找到后请在以下三部分里添加如下内容:

  3. [client]

  4. default-character-set = utf8mb4

  5. [mysql]

  6. default-character-set = utf8mb4

  7. [mysqld]

  8. character-set-client-handshake = FALSE

  9. character-set-server = utf8mb4

  10. collation-server = utf8mb4_unicode_ci

  11. init_connect='SET NAMES utf8mb4'

重启数据库

关注
打赏
1653291990
查看更多评论
立即登录/注册

微信扫码登录

0.0512s