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

Mysql存储emoji表情报错

PHP + MySQL , APP提交的数据包含表情,数据库存储失败!!!...mysql默认的所占字节数是3个字节的,对于大部分语言来说比如说汉字什么来说是足够的,但是emoji表情有日本文字转化而来,其占了4个字节,所以在存储过程中,会导致无法写入数据库mysql就会出现错误。...对于mysql5.5以上版本呢,其实支持更大字节的存储,需修改一下数据库的编码方式为utf8mb4 utf8mb4 是utf8的扩展,utf8mb4兼容utf8字符集,utf8 字符的编码、位置、存储在...修改以下两处 [mysqld]character-set-server=utf8mb4 [mysql] default-character-set=utf8mb4 重启mysql数据库服务。...TABLE_NAME convert to character set utf8mb4 collate utf8mb4_bin; (将TABLE_NAME替换成你的表名) ok,客户端不需要任何修改,再次提交数据表情一切正常

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

    Java 存储mysql数据库时如何进行Emoji表情转换和处理

    当保存字符串到数据库里出现\xF0\x9F\x92\x94类似问题时,发现竟是因为输入了Emoji表情的原因,由于我的mysql数据库是utf8字符集,而且Emoji表情等特殊符号要占四个字节,所以导致数据库不能正常存入...最后还是发现github上有个很牛逼的轻量级开源工具叫emoji-java,通过这个工具类基本上解决了我大部分的问题,同时配合前端限制Emoji表情输入,才算把问题解决。...下面附上完整的java解决Emoji表情工具类: package com.im.app.api.util; import com.github.binarywang.java.emoji.EmojiConverter...private static EmojiConverter emojiConverter = EmojiConverter.getInstance(); /** * 判断字符串中是否含有表情..."" : source.trim(); String noEmojiStr = EmojiParser.removeAllEmojis(source);//移除所有的表情之后的字符串8

    1.8K10

    MySQL插入Emoji表情

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

    4.1K10

    MySQL插入Emoji表情

    前言 今天在设计开源项目的反馈信息表时遇到了emoji表情插入失败的问题,网上找了很多解决方案,答案五花八门,没找到好使的。...经过一番折腾后,终于成功插入了emoji表情,本文就跟大家分享下我的实现过程,欢迎各位感兴趣的开发者阅读本文。...string value: '\xF0\x9F\x98\x82' for column 'comments' at row 1 实现思路 因为数据库默认是UTF-8编码格式,普通的字符串占位3个字节而表情占位...那么,我们要做的事情如下所示: 修改mysql配置文件,设置其编码格式 修改数据库字符集编码 修改数据库表字符集编码 实现过程 mysql默认读取配置的顺序为:/etc/my.cnf、/etc/mysql...image-20201201214142509 测试用例 我们来往插入一个emoji表情来测试下: UPDATE chat_system.feedback t SET t.comments = '反馈信息测试

    2.1K40

    Emoji 表情图标在 iOS 与 PHP 之间通信及 MySQL 存储

    在测试过程中我们发现,用户在 iOS 端里输入了 Emoji 表情提交到服务器以后,PHP 无法在 MySQL 数据库里正确保存,会遇到乱码的问题。下面是原因探析和解决办法。...回到 iOS 和 Web 服务器之间的通信方案,我们可以直接把 iOS 中用户输入的 Emoji 表情,通过 PHP 存入 MySQL 数据库中,如果在 iOS 中展示,直接把数据传递给 iOS,客户端应该就能正确展示表情图标了...但是,Web 开发者在开发网页端的时候就会遇到一些问题,以往直接把 Emoji 表情存储在数据库中现在则会导致乱码。...,存储在数据库中就不会有任何问题了。...在数据存储方面,当一个普通中文字符存入数据库时仍然占用 3 个字节,在存入一个 Unified Emoji 表情的时候,它会自动占用 4 个字节。所以在输入输出时都不会存在乱码的问题了。

    1.3K20

    天天都在用的 Emoji 表情包,居然是怎么存储MySQL

    现象 最近项目中存储emoji表情包的时候报错: ### Cause: java.sql.SQLException: Incorrect string value: '\xF0\x9F\x98\x81...三个字节的utf8最大能编码的Unicode字符是0xffff,任何不在基本多文本平面的Unicode字符,都无法使用MySQL的utf8字符集存储,包括emoji表情和很多不常见的汉字,以及任何新增的...mysql-connector-java版本号修改为5.1.47及以上或者8.0.13及以上的方式,修改版本号后不用再修改mysql服务配置文件即可存储emoji表情包。...其中:JRE 1.7需要connector/J 5.1.21以上 说到这里,大家应该知道如何解决emoji存储的问题了:首先根据mysql版本和Java版本选择对应的mysql-connector-java...有时候,我们的mysql-connector-java版本太低(可能历史项目中mysql或者java版本太低)或者不能更改mysql服务端配置文件,我们还可以采用第二种方案来存储emoji表情包:前端或者后端对用户数据进行编码解码处理

    1.6K30

    mysqlmysql如何存储日期数据

    一.DateTime类型 1,特点 1)以YYYY-MM-DD HH:MM:SS[.fraction]格式存储日期时间,在mysql5.6前可以只能存储到秒,在5.6后能存储到微秒 2)datetime...类型与时区无关,占用8个字节的存储空间 3)时间范围公元1000-01-01 00:00:00到9999-12-31 23:59:59,存储的时间范围非常广 二.timestamp类型 1.特点: 1...)存储了由格林尼治时间1970年1月1日到当前时间的秒数,即时间戳, 以YYYY-MM-DD HH:MM:SS.[.fraction]的格式显示,占用4个字节,实际上是以int类型来存储的 2)时间范围...4)存储的时间范围:公元1000-01-01到9999-12-31之间的日期 五.time类型 用于存储时间的数据,格式为HH:MM:SS 六.注意事项 1.不要使用字符串类型来存储日期时间的数据...存储日期时间不如使用timestamp类型,使用时更加方便,无需转换

    4.9K30

    java存储emoji表情解决方案

    1、问题产生情况 在开发IM时有些有用的头像用了emoji表情或者聊天的时候用了emoji表情,然而mysql数据库用的编码是utf8_general_ci,就是utf-8编码,结果也就报错误了...java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\xAA",...' for column 'raw_json' at row 1 2、为什么会出现这种原因 因为mysql...的utf8编码的一个字符最多3个字节,但是一个emoji表情为4个字节,所以utf8不支持存储emoji表情。...但是utf8的超集utf8mb4一个字符最多能有4字节,所以能支持emoji表情存储。 3、解决方案 方案一:修改数据库的编码集设置为utf8mb4,无论是数据库还是表,还是字段。...虽然会增加存储,但是这个可以忽略不计。

    1.3K20

    MySQL如何获取存储过程参数?

    MySQL如何获取存储过程参数? 前两天有个小伙伴问我如何查看MySQL存储过程的参数问题,这个问题还真把我问住了。于是查了查官方文档,把查看的结果分享出来,希望对大家有帮助吧。...01 MySQL 存储过程的参数 MySQL中的存储过程,可以理解成一段代码,每次调用这段代码,可以帮助你实现对应的功能,例如下面这段代码,就是帮助我们连续插入1000个记录在表t里面: delimiter...02 获取参数的2种方案 方法一、使用mysql.proc表(仅限MySQL5.7及以下版本) 在MySQL的元信息表中,可以通过mysql.proc表去查看一个存储过程的参数,如下: mysql...方法二:直接使用parameter表(MySQL5.7、MySQL8.0都适用) MySQL的parameter表是专门记录函数和存储过程的输入输出参数的。...总结: 作为一个开发同学,如何获取MySQL存储过程的输入输出参数,可能会有这方面的需求。

    3.4K60

    MySQL如何实现万亿级数据存储

    Zookeeper、MySQL binghe153 192.168.175.153 Zookeeper、MySQL binghe154 192.168.175.154 Mycat、MySQL、HAProxy...安装MySQL 小伙伴们可以关注【冰河技术】微信公众号,参考《MySQL之——源码编译MySQL8.x+升级gcc+升级cmake(亲测完整版)》 安装JDK 由于Mycat和Zookeeper的运行需要...在MySQL中创建Mycat连接MySQL的账户,如下所示。...5.测试虚拟IP的漂移 如何测试虚拟IP的漂移呢?首先,我们停止binghe151服务器上的Keepalived,如下所示。...mycat restart 如何访问高可用环境 此时,整个高可用环境配置完成,上层应用连接高可用环境时,需要连接HAProxy监听的IP和端口。比如使用mysql命令连接高可用环境如下所示。

    5.9K20
    领券