前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL插入Emoji表情

MySQL插入Emoji表情

作者头像
神奇的程序员
发布2022-04-10 09:28:45
2.1K0
发布2022-04-10 09:28:45
举报

前言

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

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

写在前面

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

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

代码语言:javascript
复制
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

实现思路

因为数据库默认是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下,添加下述代码
代码语言:javascript
复制
[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语句。
代码语言:javascript
复制
# 设置数据库字符集编码,chat_system为数据库名称,根据自己的实际情况而来
ALTER DATABASE chat_system CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  • 修改数据库表的字符集编码,登录mysql后执行下述sql语句。
代码语言:javascript
复制
# 设置数据库表字符集编码,chat_system.feedback_comment_reply为我的数据库下对应的表名称,根据自己的实际情况而来
ALTER TABLE chat_system.feedback_comment_reply CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

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

代码语言:javascript
复制
SHOW VARIABLES WHERE Variable_name LIKE 'character%' OR Variable_name LIKE 'collation%';

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

image-20201201214142509

测试用例

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

代码语言:javascript
复制
UPDATE chat_system.feedback t SET t.comments = '反馈信息测试😂' WHERE t.id = 1;

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

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

image-20201201214741613

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

image-20201201215255287

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-12-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 神奇的程序员 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 写在前面
  • 实现思路
  • 实现过程
  • 测试用例
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档