博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql插入表情符号测试_MySQL如何插入Emoji表情
阅读量:5149 次
发布时间:2019-06-13

本文共 1849 字,大约阅读时间需要 6 分钟。

前言

今天在设计开源项目的反馈信息表时遇到了emoji表情插入失败的问题,网上找了很多解决方案,答案五花八门,没找到好使的。

经过一番折腾后,终于成功插入了emoji表情,本文就跟大家分享下我的实现过程,欢迎各位感兴趣的开发者阅读本文。

写在前面

我的服务器是Mac系统,mysql使用brew安装的,windows/linux它的配置文件位置可能有些不一样,具体根据真实情况而定。

先跟大家看下它的报错信息:

chat_system> UPDATE chat_system.feedback t SET t.comments = '反馈信息测试😂' WHERE t.id = 1

[2020-12-01 21:36:08] [HY000][1366] Incorrect string value: '\xF0\x9F\x98\x82' for column 'comments' at row 1

[2020-12-01 21:36:08] [HY000][1366] Incorrect string value: '\xF0\x9F\x98\x82' for column 'comments' at row 1

db2e3c387b69c6565b5ef06347f83ce4.png

实现思路

因为数据库默认是UTF-8编码格式,普通的字符串占位3个字节而表情占位4字节,此时UTF-8就不够用了,需要采用utf8mb4字符集就能解决这个问题了。

注意:utf8mb4字符集要求数据库版本高于5.5.3。

那么,我们要做的事情如下所示:

修改mysql配置文件,设置其编码格式

修改数据库字符集编码

修改数据库表字符集编码

实现过程

mysql默认读取配置的顺序为:/etc/my.cnf、/etc/mysql/my.cnf、/usr/local/etc/my.cnf、~/.my.cnf,如果对应目录下不存在这些配置文件,则需要自己新建一个。

修改数据库配置文件my.cnf,我的文件位置在: /usr/local/etc下,添加下述代码

[mysqld]

character-set-server = utf8mb4

collation-server = utf8mb4_unicode_ci

init_connect = 'SET NAMES utf8mb4'

character-set-client-handshake = false

[client]

default-character-set=utf8mb4

[mysql]

default-character-set=utf8mb4

修改数据库字符集编码,登录mysql后执行下述sql语句。

# 设置数据库字符集编码,chat_system为数据库名称,根据自己的实际情况而来

ALTER DATABASE chat_system CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

修改数据库表的字符集编码,登录mysql后执行下述sql语句。

# 设置数据库表字符集编码,chat_system.feedback_comment_reply为我的数据库下对应的表名称,根据自己的实际情况而来

ALTER TABLE chat_system.feedback_comment_reply CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

完成上述操作后,我们来看看是否修改成功,登录mysql后执行下述sql语句。

SHOW VARIABLES WHERE Variable_name LIKE 'character%' OR Variable_name LIKE 'collation%';

显示下属信息,则表示我们已经修改完成了。

46f279b5ddcf6a36a0088277c484c1e1.png

测试用例

我们来往插入一个emoji表情来测试下:

UPDATE chat_system.feedback t SET t.comments = '反馈信息测试😂' WHERE t.id = 1;

如下所示,没有报错,插入成功。

4a642cc715740d130b915e4520486a21.png

我们用dataGrap查看下数据库表中的数据,如下所示,它显示了一个?,应该是软件无法识别。

4e70c816a7b0cf6278e4ba9363085747.png

讲道理,应该是插入成功了,我们用postman请求接口试下,成功显示出来了😄。

252e57852735bf999633630ff62d9b05.png

以上就是MySQL如何插入Emoji表情的详细内容,更多关于MySQL 插入Emoji表情的资料请关注脚本之家其它相关文章!

转载地址:http://ladnv.baihongyu.com/

你可能感兴趣的文章
UI设计的心理学
查看>>
(转)matlab练习程序(HOG方向梯度直方图)
查看>>
jQuery的收尾
查看>>
『Raid 平面最近点对』
查看>>
【ADO.NET基础-数据加密】第一篇(加密解密篇)
查看>>
CSS定位有几种?分别描述其不同
查看>>
C语言基础小结(一)
查看>>
第二章小结
查看>>
STL中的优先级队列priority_queue
查看>>
BZOJ 2223 [Coci 2009]PATULJCI | 主席树练习 (好像是个权限题啊)
查看>>
Vue源码后记-更多options参数(1)
查看>>
UE4 使用UGM制作血条
查看>>
(SPOJ1)Life, the Universe, and Everything
查看>>
http协议详解
查看>>
【每日scrum】第一次冲刺day5
查看>>
浏览器对属性兼容性支持力度查询网址
查看>>
Objective-C语法之NSSortDescriptor
查看>>
使用CSS进行定位
查看>>
C语言 链队列基本操作
查看>>
OO学习总结与体会
查看>>