MySQL 存储表情字符
2017-03-14 16:37
197 查看
修改
修改数据库配置文件
重启之后,登录 mysql,可以通过
然后再修改相应的数据库表的编码为 utf8mb4:
转换数据表编码的语句格式如下:
客户端
使用不同的编程语言的时候,可能会对 utf8mb4 不支持,不能在连接字符串中指定的,此时可以在获取连接之后,执行
比如,对于 ThinkPHP 框架,在配置文件中设置数据库连接字符集为 utf8mb4 之后(
此时,由于我们已经在 mysql 的配置文件中设置了
MySQL 默认情况下,无法存储中文字符,其实这和 MySQL 默认无法存储表情字符是同样的原因:数据库字符编码问题。
默认情况下,MySQL 使用的字符集是 Latin,所以无法存储中文或者其他的一些字符。
如果要存储中文,可以设置 MySQL 的字符集为支持中文的字符集,比如 GBK 或者 UTF-8。一般情况下,我们设置为 UTF-8,能有更好的兼容性。
修改 MySQL 配置文件
重启 mysqld 服务,使刚才的修改生效
如果数据库中已经建有数据表了,那么还需要将这些数据表的字符集做更改。如果数据表有很多,可以导出数据库和数据,然后重新建库。
服务器端
修改数据库配置文件/etc/my.cnf,添加下面的配置,然后重启服务器:
重启之后,登录 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,能有更好的兼容性。
修改 MySQL 配置文件
/etc/my.cnf,添加下面的配置,然后重启服务器:
如果数据库中已经建有数据表了,那么还需要将这些数据表的字符集做更改。如果数据表有很多,可以导出数据库和数据,然后重新建库。
相关文章推荐
- MySQL 存储表情字符
- mysql 存储字符表情
- MySQL 存储表情字符
- MySQL 存储表情字符
- MySql5.7.14存储表情字符报错Incorrect string value
- MySql5.7.14存储表情字符报错Incorrect string value
- MySQL 存储表情字符
- mysql存储中文字符乱码
- Emoji表情图标在iOS与PHP之间通信及MySQL存储
- MySQL字符分割并存储到临时表中
- 修改Mysql 字符集,支持Emoji表情(如搜狗的自定义表情大字符)
- 使MySQL能够存储emoji表情字符的设置教程
- Mysql的varchar(20)到底可以存储多少个中文字符
- MySQL存储包含特殊字符的字符串时为空
- mysql 支持emoji 表情字符的解决方法。
- mysql修改默认字符和默认存储引擎
- mysql对emoji特殊字符进行存储
- 使用Hibernate向MySQL存储中文字符数据
- mysql存储过程用游标解决返回的结果级并拼装字符
- emoji表情在web的展示与mysql存储方式