在获取微信名称并存入数据库时报错:
java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\x94' for column 'name' at row 1
解决办法是将新的数据库的编码从utf8修改为utf8mb4.
修改mysql的配置文件my.cnf
[client]
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='SET NAMES utf8mb4'my
重启数据库
设置数据库、表、存储emoji字段的编码格式:utf8mb4
检查配置:
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';
+--------------------------+--------------------+
| Variable_name | Value |
+--------------------------+--------------------+
| character_set_client | utf8mb4 |
| character_set_connection | utf8mb4 |
| character_set_database | utf8mb4 |
| character_set_filesystem | binary |
| character_set_results | utf8mb4 |
| character_set_server | utf8mb4 |
| character_set_system | utf8 |
| collation_connection | utf8mb4_unicode_ci |
| collation_database | utf8mb4_unicode_ci |
| collation_server | utf8mb4_unicode_ci |
+--------------------------+--------------------+
rows in set (0.00 sec)
如果出现以上信息,说明配置已经成功。
但是...
但是...
但是....我的按配置改完后查询发现主要参数还都是utf8的,
后来在代码中配置连接池的地方,增加一行参数:
<property name="connectionInitSqls" value="set names utf8mb4;"/>
数据库连接url :ip数据库后面: ?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true
设置完再一试成功!