时间:2021-07-01 10:21:17 帮助过:28人阅读
UTF-8编码有可能是两个、三个、四个字节。Emoji表情是4个字节,而Mysql的utf8编码最多3个字节,所以数据插不进去。
解决方法:
1、修改mysql配置文件my.ini
找到配置文件是关键,可在window服务找到mysql的服务,右键属性查看,如图:
打开配置文件,在响应的节点追加以下内容:
[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‘
2、修改数据库及表结构,命令行如下:
ALTER DATABASE ‘database’ CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;
ALTER TABLE ‘tablename‘ CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
ALTER TABLE ‘tablename‘ modify ‘columnName‘ text CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
3、修改java程序中的数据库连接字符串,不要设置 characterEncoding,设置autoReconnect=true,连接串如下:
jdbc:mysql://127.0.0.1:3306/dbname?useUnicode=true&autoReconnect=true&allowMultiQueries=true
4、最后一步,重启mysql数据库,重启web服务器。
ok,搞定!
Mysql插入Emoji表情出错
标签:出错 .exe mysql配置 ror character web amp pack 服务器