赞
踩
在连接字符串中,
jdbc:mysql://localhost:3306/db名称?useUnicode=true&characterEncoding=utf8
存储4字节utf8时,报错如下(从别人那里拷贝的。呵呵)
java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\x94' for column 'name' 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)
解决办法:
创建数据库连接后,执行一条sql语句:Set names utf8mb4
执行后,可以使用SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';检查
其中,character_set_client 和character_set_connection为utf8mb4。
再在这个连接执行,4字节utf8就可以存储上了。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。