java - 无法使用 mysql 和 hibernate 保存表情符号

标签 java mysql hibernate unicode

我实际上在 Stackoverflow 上多次发现这个问题,但解决方案对我没有帮助。

我的 Android 应用程序中有一个聊天模块,我想将消息保存在我的服务器数据库中,这在出现特殊字符(如表情符号)之前工作正常。

ERROR: Incorrect string value: '\xF0\x9F\x98\x81' for column 'message' at row 1
...
...
Caused by: java.sql.SQLException: Incorrect string value: '\xF0\x9F\x98\x81' for column 'message' at row 1
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1084)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4232)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4164)
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2615)
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2776)
    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2838)
    at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2082)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2334)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2262)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2246)
    at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:187)
... 23 more

我的环境是:

-Mysql 5.6
-Tomcat 8.0.8
-Hibernate 4.3.5
-JDK 1.8.0_05

这是使用过的表,其中包含有问题的列“消息”:

table properties

这些是我在 persistence.xml(版本 2.1)中的属性:

<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/gamedb?useUnicode=true&amp;characterEncoding=UTF-8" />
<property name="javax.persistence.jdbc.user" value="*********" />
<property name="javax.persistence.jdbc.password" value="**************" />

<property name="hibernate.hbm2ddl.auto" value="update" />
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect" />
<property name="hibernate.connection.useUnicode" value="true" />
<property name="hibernate.connection.characterEncoding" value="utf8" />

现在我尝试了以下解决方案没有效果:

-Change datatype of 'message' from varchar to longtext
-Change collation of 'message' to utf8mb4
-Change collation of table to utf8mb4
-Append url with "?useUnicode=true&amp;characterEncoding=UTF-8"
-Set character-set-server of mysql to utf8mb4

我认为表情符号已正确传输到服务器,在它保留消息之前,它会将消息广播回应用程序并正确显示。

最佳答案

我曾经遇到过同样的问题。我不知道一个很好的解决方案,但这对我有用。

创建 Session 对象后,我手动更改了连接排序规则:

s.doReturningWork(new ReturningWork<Object>() {
    @Override
    public Object execute(Connection conn) throws SQLException
    {
        try(Statement stmt = conn.createStatement()) {
            stmt.executeQuery("SET NAMES utf8mb4");
        }

        return null;
    }
});

关于java - 无法使用 mysql 和 hibernate 保存表情符号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24886504/

相关文章:

java - 两个java对象HashCode如何相似

mysql - 如何从嵌套选择中获取嵌套的两个值? mysql

mysql - sql建表不起作用

mysql - SQL 查询处理 NULL

java - 如何获取 1 :M entity from parent class with limit?

java - 初学者处理Java异常

java - Android 尝试旋转图像时出现 OutOfMemoryError

java : Comparable vs Comparator

Glassfish 中的 hibernate - Ejb3Configuration NoClassDefFoundError

java - 在列中按两次排序