首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL插入Emoji表情

前言 今天在设计开源项目的反馈信息表时遇到了emoji表情插入失败的问题,网上找了很多解决方案,答案五花八门,没找到好使的。...经过一番折腾后,终于成功插入了emoji表情,本文就跟大家分享下我的实现过程,欢迎各位感兴趣的开发者阅读本文。...那么,我们要做的事情如下所示: 修改mysql配置文件,设置其编码格式 修改数据库字符集编码 修改数据库表字符集编码 实现过程 mysql默认读取配置的顺序为:/etc/my.cnf、/etc/mysql...] default-character-set=utf8mb4 修改数据库字符集编码,登录mysql后执行下述sql语句。...测试用例 我们来往插入一个emoji表情来测试下: UPDATE chat_system.feedback t SET t.comments = '反馈信息测试?'

4.1K10

MySQL插入Emoji表情

前言 今天在设计开源项目的反馈信息表时遇到了emoji表情插入失败的问题,网上找了很多解决方案,答案五花八门,没找到好使的。...经过一番折腾后,终于成功插入了emoji表情,本文就跟大家分享下我的实现过程,欢迎各位感兴趣的开发者阅读本文。...那么,我们要做的事情如下所示: 修改mysql配置文件,设置其编码格式 修改数据库字符集编码 修改数据库表字符集编码 实现过程 mysql默认读取配置的顺序为:/etc/my.cnf、/etc/mysql...] default-character-set=utf8mb4 修改数据库字符集编码,登录mysql后执行下述sql语句。...image-20201201214142509 测试用例 我们来往插入一个emoji表情来测试下: UPDATE chat_system.feedback t SET t.comments = '反馈信息测试

2.1K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql存储emoji问题

    前一段时间,项目中需要在数据库中存储emoji,由于编码格式不对,直接导致数据库报错,后来修改mysql的编码,就解决了 emoji符号实际上是文本,并不是图片,它们仅仅显示为图片 在mysql5.5.3...或更高的版本才支持 确定数据库支持存储表情后,可以修改数据库的默认编码,这样以后再建数据库的话,就不用考虑存emoji这个问题了 在mysql 的配置文件 my.cnf 或 my.ini 配置文件中修改如下...,然后使用以下命令查看编码,应该全部为utf8mb4(character_set_filesystem和character_set_system除外): mysql> show variables like...现在,MySQL就可以正确存储emoji字符了。 但是如果是之前已经建好的数据库怎么办呢?...可以使用 mysql命令 ALTER TABLE 表名 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_general_ci; 来更改已有的数据库表的编码 参考地址:

    88260

    mysql 插入 emoji报错1366

    最近做项目需要用到emoji表情,好不容易把前端搞定,提交数据到后台发现无法插入数据库,异常提示如下: org.springframework.jdbc.UncategorizedSQLException...编码格式问题,解决问题后总结如下: 1、mysql版本5.5.3+,必须升级到较新版本 2、mysql connection版本高于5.1.13 3、修改mysql字符集 按照网上收集资料进行了mysql...字符集修改,字符集已经修改如下图,仍然无法插入emoji表情,仔细排查了一下是因为字段未修改成utf8mb4,通过下面第一种方法中的字段修改代码修改后即可成功插入。...时候,mysql字符集通过my.cnf已经设置成了 utf8mb4,使用的Navicat工具连接数据库,无法直接在数据库表格中添加emoji,仍然会报’\xF0\x9F\x8D\x85\xF0\x9F…...,这个太坑了,折腾了几个小时仍然没有好,后来用SQLyog客户端工具连接数据库,打开一看都是正常显示,也可以直接在数据库表格中复制粘贴添加emoji表情,不知道是不是Navicat工具的bug。

    1.7K20

    Mysql存储emoji表情报错

    PHP + MySQL , APP提交的数据包含表情,数据库存储失败!!!...mysql默认的所占字节数是3个字节的,对于大部分语言来说比如说汉字什么来说是足够的,但是emoji表情有日本文字转化而来,其占了4个字节,所以在存储过程中,会导致无法写入数据库mysql就会出现错误。...对于mysql5.5以上版本呢,其实支持更大字节的存储,需修改一下数据库的编码方式为utf8mb4 utf8mb4 是utf8的扩展,utf8mb4兼容utf8字符集,utf8 字符的编码、位置、存储在...在mysql的安装路径下找到,配置文件: Linux系统找my.cfg文件,在windows系统下找my.ini 。...修改以下两处 [mysqld]character-set-server=utf8mb4 [mysql] default-character-set=utf8mb4 重启mysql数据库服务。

    1.1K30

    mysql乱码设置

    MySQL默认字符编码的设置 MySQL的默认编码是Latin1,不支持中文,那么如何修改MySQL的默认编码呢,下面以UTF-8为例来说明  需要注意的是,要修改的地方非常多,相应的修改方法也很多...下面是一种最简单最彻底的方法:  一、Windows  1、中止MySQL服务  2、在MySQL的安装目录下找到my.ini,如果没有就把my-medium.ini复制为一个my.ini...即可  3、打开my.ini以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭  4、启动MySQL服务  二、Linux... 1、中止MySQL服务(bin/mysqladmin -u root shutdown)  2、在/etc/下找到my.cnf,如果没有就把MySQL的安装目录下的support-files.../etc/下并改名为my.cnf即可  3、打开my.cnf以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭  4、启动MySQL

    3.8K60

    踩坑经验 | Mysql导入emoji报错

    踩坑经验 | Mysql导入emoji报错 上周遇到了中文长度的问题之后,就想起了很久之前遇到的这个问题,也是一个和长度相关的问题。...但是数据入库的时候发生了报错,通过排查报错的数据之后发现,报错来自于微信昵称这个字段中的emoji字符。 上周末的推送讲了,在mysql中,中文是占3个字节的。而emoji比较特殊,占4个字符。...mysql默认使用的的UTF-8只支持三个字节的存储,而一般字符是三个字节,但是emoji表情是4个字节,所以存储不了。因此,有表情的字段上就有将该字段设置为utf8mb4。...根据各种资料收集的结果来看,不同版本的mysql对于设置这里是有细微的区别的。...不过还有另一种解决问题的方案,那就是——直接把emoji转成varchar进行存储。

    30320

    Mysqlemoji表情(base64编码)

    Mysql的utf8编码为何存储不了Emoji表情?...Emoji 首先的知道Emoji的编码方式,Emoji即绘文字,绘意指图形,文字则是图形的隐喻,可用来代表多种表情,如笑脸表示笑、蛋糕表示食物等。...总结来说Emoji对应的Unicode编码不在utf8对应的Unicode分组平面内,无法直接用Mysql的utf8存储Emoji编码格式字符。...让Mysql支持Emoji表情的多种方式 修改Mysql的表面为utf8_mb4 1 这种做法,网上有很多教程这里不做细致说明。...总结 本人也是遇到数据库存储Emoji报错,为了解决这个问题,网上搜索资料总得了这几点,给出以下两篇文章,推荐大家去阅读,理解MySql在utf8下为什么不能存储Emoji表情,理解Unicode基本知识

    3.1K30

    python 读取 mysql 中文乱码

    这两天看了很多关于mysql中文乱码的问题,除了创建table的时候设置为utf8编码以及修改mysql配置文件的方法外,很少有人提关于python库中中文乱码的处理办法,尤其是records库的中文乱码问题..., config.mysql_user, config.mysql_pass, config.mysql_db, charset='utf8') cursor = db.cursor()...records库是requests作者 kennethreitz 写的一个非常方便的针对各种数据库进行数据处理的python库,只不过文档和网上的相关内容很少,尤其是中文的情况,如果不知道正确的使用方法很容易出现乱码...mysql4read = 'mysql://{user}:{passwd}@{host}:3306/{db}'.format(host=host, user=user, passwd=pass, db=...for row in db.query(sql).as_dict(): print(row) 可以看到一定要在创建db对象的时候传入connect_args参数,否则中文很容易出现乱码

    5.2K20

    MySQL乱码问题如何排查

    MySQL客户端和服务器是怎么通信的? 1.首先请求会被MySQL客户端编码为字节序列之后通过网络传输到服务器。...启动MySQL客户端时,MySQL客户端就会检测到这个操作系统使用的是utf8字符集,并将客户端默认字符集设置为utf8。...character_set_connection character_set_results 服务器向客户端返回数据时使用的字符集(服务器采用该系统变量指定的字符集对返回给客户端的字符串进行编码) 从通信转码流程来看,要保证没有乱码出现...结论 解决乱码问题,要从客户端到服务器通信流程中的字符集编码、转码、解码来分析是哪一步的问题。...一般情况下,保证: character_set_client character_set_results character_set_connection 客户端的字符集编码 当其一致时就可解决乱码问题

    1.6K10
    领券