摘要

在 MySQL 中直接存储表情的时候,会出现无法插入数据的错误。

这是由于一般情况下,MySQL 的字符集是 utf8,而对于 emoji 表情的 mysql 的 utf8 字符集是不支持,需要修改设置为 utf8mb4 才行。

摘引:mysql utf8mb4与emoji表情 MYSQL 5.5 之前, UTF8 编码只支持1-3个字节,只支持BMP这部分的unicode编码区(BMP是从哪到哪),基本就是0000~FFFF这一区。 从MYSQL5.5开始,可支持4个字节UTF编码utf8mb4,一个字符最多能有4字节,所以能支持更多的字符集。 utf8mb4 is a superset of utf8,utf8mb4兼容utf8,且比utf8能表示更多的字符。在做移动应用时,会遇到用户会输入emoji表情,如果不做一定处理,就会导致插入数据库异常。

修改

服务器端

修改数据库配置文件/etc/my.cnf,添加下面的配置,然后重启服务器:

[mysqld]
character-set-server=utf8mb4
collation_server=utf8mb4_unicode_ci
init-connect="SET NAMES utf8mb4" [mysql]
default-character-set=utf8mb4

  

重启之后,登录 mysql,可以通过show variables like 'character%';查看编码是否已经修改成功。修改成功应该类似如下:

mysql> show variables like '%char%';
+--------------------------+----------------------------------+
| Variable_name | Value |
+--------------------------+----------------------------------+
| character_set_client | utf8mb4 |
| character_set_connection | utf8mb4 |
| character_set_database | utf8mb4 |
| character_set_filesystem | binary |
| character_set_results | utf8mb4 |
| character_set_server | utf8mb4 |
| character_set_system | utf8 |
| character_sets_dir | /usr/local/mysql/share/charsets/ |
+--------------------------+----------------------------------+
8 rows in set (0.00 sec)

然后再修改相应的数据库表的编码为 utf8mb4:

ALTER TABLE tbl_name CONVERT TO CHARACTER SET utf8mb4;

转换数据表编码的语句格式如下: ALTER TABLE tbl_name CONVERT TO CHARACTER SET charset_name;

客户端

使用不同的编程语言的时候,可能会对 utf8mb4 不支持,不能在连接字符串中指定的,此时可以在获取连接之后,执行set names utf8mb4来解决这个问题。

比如,对于 ThinkPHP 框架,在配置文件中设置数据库连接字符集为 utf8mb4 之后('DB_CHARSET'=>'utf8mb4'),会出现错误,提示无法使用这个字符集。

此时,由于我们已经在 mysql 的配置文件中设置了init-connect="SET NAMES utf8mb4",所以直接将 ThinkPHP 配置文件中的数据库字符集设置为空('DB_CHARSET'=>''),则连接数据库之后,服务器会自动设置连接字符集为 utf8mb4,此时写入和读取 emoji 表情就能正常了。

扩展

MySQL 默认情况下,无法存储中文字符,其实这和 MySQL 默认无法存储表情字符是同样的原因:数据库字符编码问题。

默认情况下,MySQL 使用的字符集是 Latin,所以无法存储中文或者其他的一些字符。

如果要存储中文,可以设置 MySQL 的字符集为支持中文的字符集,比如 GBK 或者 UTF-8。一般情况下,我们设置为 UTF-8,能有更好的兼容性。

  1. 修改 MySQL 配置文件/etc/my.cnf,添加下面的配置,然后重启服务器:

    [mysqld]
    character-set-server=utf8 [mysql]
    default-character-set=utf8
  2. 重启 mysqld 服务,使刚才的修改生效

  3. 如果数据库中已经建有数据表了,那么还需要将这些数据表的字符集做更改。如果数据表有很多,可以导出数据库和数据,然后重新建库。

    ALTER TABLE tbl_name CONVERT TO CHARACTER SET utf8

结语

如果你还需要了解更多技术文章信息,请继续关注白衣秀才的博客
个人网站:http://penglei.top/
Github:https://github.com/whitescholars
微博:http://weibo.com/u/3034107691?refer_flag=1001030102_&is_all=1

MySQL 存储表情字符的更多相关文章

  1. mysql存储表情字符

    windows下是my.inilinux下是my.cnf 路径是: /etc/my.cnf 参考: https://blog.csdn.net/fhzaitian/article/details/53 ...

  2. SpringMvc+Hibernate+Mysql保存表情字符(昵称)到数据库报错的问题?

    背景: 一个中小型H5游戏 描述: 游戏通过微信授权登入, 获取到用户昵称并将用户信息保存至Mysql数据库, 当遇到有些用户微信昵称中带有表情(特殊字符)时, 保存至数据库出错! 核心错误: Cau ...

  3. mysql 无法存储表情字符 java.sql.SQLException: Incorrect string value: '\xF0\x9F\x90\xBE",...' for column 'XXXX' at row 1

    1.变更字段类型 ALTER TABLE api_log MODIFY COLUMN remark longtext CHARACTER SET utf8mb4 COLLATE utf8mb4_uni ...

  4. 微信emoji表情编码 、MySQL 存储 emoji 表情符号字符集

    相关资料 微信emoji表情编码 微信用户名显示「emoji表情」 PHP处理微信中带Emoji表情的消息发送和接收(Unicode字符转码编码) MySQL 存储emoji表情 MySQL 存储 e ...

  5. Emoji表情图标在iOS与PHP之间通信及MySQL存储

    在某个 iOS 项目中,需要一个服务器来保存一些用户数据,例如用户信息.评论等,我们的服务器端使用了 PHP+MySQL 的搭配.在测试过程中我们发现,用户在 iOS 端里输入了 Emoji 表情提交 ...

  6. mysql无法压缩存储表情

    原文链接:https://www.cnblogs.com/SimonHu1993/p/7573868.html mysql无法压缩存储表情compress(str),就选择过滤把emoji表情符号替换 ...

  7. mysql存储emoji表情报错的处理方法【更改编码为utf8mb4】

    utf-8编码可能2个字节.3个字节.4个字节的字符,但是MySQL的utf8编码只支持3字节的数据,而移动端的表情数据是4个字节的字符.如果直接往采用utf-8编码的数据库中插入表情数据,Java程 ...

  8. mysql中对字符集和校对规则的认识

    字符集:指符号和字符编码的集合.校对规则:比较字符编码的方式.GBK2312:主要包括简体中文字符及常用符号,对于中文字符采用双字节编码的格式,也就是说一个汉字字符在存储占两个字节.GBK:包括有中. ...

  9. mysql存储emoji问题

    前一段时间,项目中需要在数据库中存储emoji,由于编码格式不对,直接导致数据库报错,后来修改mysql的编码,就解决了 emoji符号实际上是文本,并不是图片,它们仅仅显示为图片 在mysql5.5 ...

随机推荐

  1. SpringMVC轻松学习-SpringMVC介绍(一)

    Spring  MVC 背景介绍 Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块.使用 Spring 可插入的 MVC 架构,可以选择是使用内置的 Spring Web 框架还是 ...

  2. Oracle GoldenGate 异构平台同步(Mysql到Oracle)

    一.OGG安装配置(源端) 1.OGG下载 http://www.oracle.com/technetwork/cn/middleware/goldengate/downloads/index.htm ...

  3. python--字符串操作(删除,替换)

    示例: 替换字符串开头和结尾处的空格 1. [代码][Python]代码     跳至 [1] [全屏预览] view source print? 01 # -*- coding: utf-8 -*- ...

  4. STM32内置参照电压的使用(转)

    源:STM32内置参照电压的使用 每个STM32芯片都有一个内部的参照电压,相当于一个标准电压测量点,在芯片内部连接到ADC1的通道17. 根据数据手册中的数据,这个参照电压的典型值是1.20V,最小 ...

  5. Eclipse 的 git 插件操作 "代码提交"以及"代码冲突"

    面向对象:曾经使用过SVN的同学. (因为Git 它 可以说是双重的SVN (本地一个服务器,远程一个服务器)),提交代码要有两次步骤,先提交到本地服务器,再把本地服务器在提交到远程服务器. 所以连S ...

  6. ue4访问php接口

    继上一篇介绍ue4打开web url窗口,这篇就来介绍下怎么访问php接口. 要做的两步: 1.c++自己写个接受请求的方法 f Post lhc-URL Request就是自定义的c++方法, /* ...

  7. salt自动化部署

    1. 到编译机器编译 /export/Deploy/vm-agent 执行脚本 ./vm-agent.sh develop -alpha 2.检查rpm包是否打包成功 http://172.18.13 ...

  8. 获取url参数和时间格式化

    1. 获取url参数: var url = request("url"); //获取url参数 function request(paras) { //decodeURI() 函数 ...

  9. MongoDB升级教程

    1.排序 sort()方法:其中 1 为升序排列,而-1是用于降序排列. db.col.find({},{"title":1,_id:0}).sort({"likes&q ...

  10. Unity中使用扩展方法解决foreach导致的GC

    对于List这种顺序表,我们解决的时候还是可以使用for代替foreach即可.但是对于非顺序表,比如Dictionary或者Set之类,我们可以扩展方法Foreach,ForeachKey和Fore ...