mysql存储表情报错

阅读: 评论:0

mysql存储表情报错

mysql存储表情报错

本人使用的是mysql数据库,引擎默认使用的是InnoDB(其实跟引擎没关系).字符集为utf8

当保存emjoy表情的时候就报错了,很难受.为什么会这样呢

百度一下网上的资料,最后

总结

早期的mysql版本将utf8编码设置为1~3个字节,而emoji表情是4个字节,存到utf8编码的字段里当然报异常了.

为此mysql后续增加utf8mb4编码.完美的兼容了emoji表情的保存

Linux设置mysql字符编码

本人的linux系统为centos7.4.过程如下

1. 进入文件编辑 vim /etc/myf

2.在[mysqld]添加

character-set-server=utf8mb4

3.重启服务service mysql restart

5.查看mysql字符集

mysql>SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';

OK,完美解决

下面这么设置更为彻底

[client]

default-character-set = utf8mb4

[mysqld]

character-set-client-handshake = false

character-set-server = utf8mb4

init_connect='SET NAMES utf8mb4'

[mysql]

default-character-set = utf8mb4

MySQL混合utf8 utf8mb4是否比纯utf8mb4更具优势?

其实都差不多.utf8mb4其实就是标准的utf8.他可以实现存储4个字节的emjoy表情而utf8不行

另外需要注意的一点就是utf8mb4的表字段最好不要用char固定字符.因为N个char字符所占用的空间是N*4字节.建议改用可变长度的varchar进行存储.效率方面稍好(增加额外的1-2字节记录其字段大小)

而纯英文字符的字段(例如密码等).可以用varbinary(可变长度binary)和binary列(适用于固定长度的英文字符, 例如密码哈希)类型.性能比varchar略好, 因为这个存储二进制数据

本文发布于:2024-02-01 06:54:39,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170674167934700.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:报错   表情   mysql
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23