mysql保存emoji表情的方法

  介绍

这篇文章给大家分享的是有关mysql保存emoji表情的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

java.sql.SQLException:, Incorrect  string 价值:,& # 39;\ xF0 \ x9F \ x92 \ x94& # 39;, for  colum  n  & # 39;名字# 39;,at  row  1, at  com.mysql.jdbc.SQLError.createSQLException (SQLError.java: 1073),   at  com.mysql.jdbc.MysqlIO.checkErrorPacket (MysqlIO.java: 3593),   at  com.mysql.jdbc.MysqlIO.checkErrorPacket (MysqlIO.java: 3525),   at  com.mysql.jdbc.MysqlIO.sendCommand (MysqlIO.java: 1986),   at  com.mysql.jdbc.MysqlIO.sqlQueryDirect (MysqlIO.java: 2140),   at  com.mysql.jdbc.ConnectionImpl.execSQL (ConnectionImpl.java: 2620),   at  com.mysql.jdbc.StatementImpl.executeUpdate (StatementImpl.java: 1662),   at  com.mysql.jdbc.StatementImpl.executeUpdate (StatementImpl.java: 1581)

当报以上错误的时候,可能是java代码中的字段与数据库中的字段类型或者编码不匹配,这种情况只要统一格式或者编码就就可以了。

这里主要介绍emoji的图像插入数据库的错误以及解决方法

使用mysql数据库的时候,如果字符集是utf - 8并且在java服务器上,当存储emoji表情的时候,会抛出以上异常(比如微信开发获取用户昵称,有的用户的昵称用的是emoji的图像)

这是由于字符集不支持的异常,因为utf - 8编码有可能是两个,三个,四个字节,其中emoji表情是四个字节,而mysql的utf - 8编码最多三个字节,所以导致数据插不进去。
解决方式:
一。从数据库层面进行解决(mysql支持utf8mb4的版本是5.5.3 +,必须升级到较新版本)
,,,注意:
,,,(1.修改数据库、表、列字符集

ALTER  DATABASE  database_name  CHARACTER  SET =, utf8mb4  COLLATE =, utf8mb4_unicode_ci; ALTER  TABLE  table_name  CONVERT 用CHARACTER  SET  utf8mb4  COLLATE  utf8mb4_unicode_ci; ALTER  TABLE  table_name  CHANGE  column_name  VARCHAR (191), CHARACTER  SET  utf8mb4  COLLATE  utf8mb4_unicode_ci;


,,,(2。修改mysql配置文件my.cnf(窗口为my.ini)

[客户]   default-character-set =utf8mb4   (mysql)   default-character-set =utf8mb4   (mysqld)   character-set-client-handshake =FALSE   character-set-server =utf8mb4   collation-server =utf8mb4_unicode_ci   init_connect=& # 39; SET  NAMES  utf8mb4& # 39;


,,,(3。用的是java服务器,升级或者确保mysql连接版本高于5.1.13否则仍然不能试用utf8mb4
,,,(4。服务器端的db配置文件

jdbc.driverClassName=com.mysql.jdbc.Driver   jdbc.url=jdbc: mysql://localhost: 3306/数据库? useUnicode=true& characterEncoding=utf8& autoReconnect=true& rewriteBatchedStatements=TRUE   jdbc.username=根   jdbc。密码=密码


,,如果升级了mysql-connector,其中的characterEncoding=utf8可以自动被识别为utf8mb4(兼容原来的utf8),而
,,autoReconnection(当数据库连接异常中断时,是否自动重新连接?默认为false)强烈建议配上,忽略这个属性,可能导致缓存缘故,
,,没有读取到DB最新的配置,导致一直无法试用utf8mb4字符集;

二。从应用层的方面进行解决
,,在获得数据之后往数据库存之前先进行编码:

URLEncoder.encode(昵称,“utf-8");

当从数据库中取出准备显示的时候进行解码,

URLDecoder.decode(昵称,“utf-8");

从应用层进行解决的时候建议不要在对象getter、setter方法中直接编码,因为放入对象的时候setter方法将昵称进行编码,当插入数据库的时候相当于从对象中调用getter方法将你参考取出这就将之前setter编码过的绰号又重新解码了,等于未对昵称进行任何操作。依然会出现以上问题。

感谢各位的阅读!关于“mysql保存emoji表情的方法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

mysql保存emoji表情的方法