资讯专栏INFORMATION COLUMN

MySQL 字符集问题

赵春朋 / 2949人阅读

摘要:最近公司一个旧的项目需要支持表情,一开始以为只要修改下数据库的表字段就好,没想到引发了一系列的问题。将操作结果从内部操作字符集转换为响应请求。

最近公司一个旧的项目需要支持 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_clientcharacter_set_connectioncharacter_set_results 的字符集相同,且都为utf8mb4(这三个参数默认都是utf8mb4,如果不是,是实现不了 emoji 表情的,原因参照字符集转换过程)。

连接数据库的字符集也需要是utf8mb4

character_set_servercharacter_set_database 等默认字符集的类型并没有那么重要,但最好还是保持一致

TP 的坑果然是多,远离TP

参考

http://www.laruence.com/2008/...

http://stackoverflow.com/ques...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/22531.html

相关文章

  • mysql/Java服务端对emoji的支持

    摘要:前言最近开发的项目因为需要用户文本的存储,自然就遇到了等表情符号如何被支持的问题。问题描述如果字符集且是服务器的话,当存储含有表情时,会抛出类似如下异常这就是字符集不支持的异常。升级步骤的最低版本支持版本为,若不是,请升级到较新版本。   前言: 最近开发的iOS项目因为需要用户文本的存储,自然就遇到了emoji等表情符号如何被mysql DB支持的问题。困扰了数日,在就要绝望放弃...

    lncwwn 评论0 收藏0
  • Application无法传递Emoji字符MySQL问题

    摘要:中无法存储字符,源自于之前编码只支持最大个字节,而需要个字节。事实上,如果只是某个列存在字符的存储问题,那就只需要修改这个列的编码类型即可。这涉及到应用与建立连接的问题。有一条命令是,会将的编码统一设置。使用这条命令便可以达到我们的目的。 MySQL中无法存储Emoji字符,源自于MySQL 5.5之前utf8编码只支持最大3个字节,而Emoji需要4个字节。从MySQL 5.5开始,...

    dmlllll 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<