摘要:最近公司一个旧的项目需要支持表情,一开始以为只要修改下数据库的表字段就好,没想到引发了一系列的问题。将操作结果从内部操作字符集转换为响应请求。
最近公司一个旧的项目需要支持 emoji 表情,一开始以为只要修改下数据库的表字段就好,没想到引发了一系列的问题。这里总结下,以作备忘。
01 MySQL 字符集设置
系统变量:
character_set_server: 默认的内部操作字符集
character_set_client: 客户端来源数据使用的字符集
character_set_connection:连接层字符集
character_set_results: 查询结果字符集
character_set_database: 当前选中数据库的默认字符集
character_set_system: 系统元数据(字段名等)字符集
02 MySQL 中的字符集转换过程
MySQL Server收到请求时将请求数据从 character_set_client 转换为character_set_connection;
进行内部操作前将请求数据从 character_set_connection 转换为内部操作字符集,其确定方法如下:
使用表中字段的 CHARACTER SET 设定值;
若上述值不存在,则使用对应数据表的 DEFAULT CHARACTER SET 设定值(MySQL扩展,非SQL标准);
若上述值不存在,则使用对应数据库的 DEFAULT CHARACTER SET 设定值;
若上述值不存在,则使用 character_set_server 设定值。
将操作结果从内部操作字符集转换为 character_set_results, 响应请求。
03 MySQL 启动配置文件 my.cnf
default-character-set: 设置 mysql 命令行连接的默认字符集
character-set-server: 设置系统内部操作字符集(即上文说到的character_set_server)
collation_server: 设置系统默认字符集排序
04 PHP连接 MySQL(以PDO连接方式为例)
常见的两种设置字符集的方式
mysql:host=localhost;dbname=db_demo;charset=utf8mb4
PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8mb4"
05 总结
数据表字段的字符集需要是utf8mb4,这个是刚需
一般 character_set_client、character_set_connection、character_set_results 的字符集相同,且都为utf8mb4(这三个参数默认都是utf8mb4,如果不是,是实现不了 emoji 表情的,原因参照字符集转换过程)。
连接数据库的字符集也需要是utf8mb4
character_set_server、character_set_database 等默认字符集的类型并没有那么重要,但最好还是保持一致
TP 的坑果然是多,远离TP
参考
http://www.laruence.com/2008/...
http://stackoverflow.com/ques...
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/22531.html
摘要:前言最近开发的项目因为需要用户文本的存储,自然就遇到了等表情符号如何被支持的问题。问题描述如果字符集且是服务器的话,当存储含有表情时,会抛出类似如下异常这就是字符集不支持的异常。升级步骤的最低版本支持版本为,若不是,请升级到较新版本。 前言: 最近开发的iOS项目因为需要用户文本的存储,自然就遇到了emoji等表情符号如何被mysql DB支持的问题。困扰了数日,在就要绝望放弃...
摘要:中无法存储字符,源自于之前编码只支持最大个字节,而需要个字节。事实上,如果只是某个列存在字符的存储问题,那就只需要修改这个列的编码类型即可。这涉及到应用与建立连接的问题。有一条命令是,会将的编码统一设置。使用这条命令便可以达到我们的目的。 MySQL中无法存储Emoji字符,源自于MySQL 5.5之前utf8编码只支持最大3个字节,而Emoji需要4个字节。从MySQL 5.5开始,...
阅读 2426·2021-11-23 09:51
阅读 481·2019-08-30 13:59
阅读 1793·2019-08-29 11:20
阅读 2514·2019-08-26 13:41
阅读 3217·2019-08-26 12:16
阅读 713·2019-08-26 10:59
阅读 3262·2019-08-26 10:14
阅读 575·2019-08-23 17:21