mysql数据库存储表情都是问号_数据库保存中文全为问号以及emoji表情保存出错...

2ff34e647e2e3cdfd8dca593e17d9b0a.png

前两天在做微信接入的时候,获取用户的nickname保存到数据库时出现异常,发现是用户名中带有emoji表情,以及从微信传过来的居然是ISO-8859-1编码,真的很坑,名字里的中文全变成问号。

以下是解决方案:

mysql5.5以上的版本引入了utf8mb4编码格式以支持emoji格式,是utf8的超集,支持中文和emoji。

修改数据库、表字符集为utf8mb4

1、在[client]字段里加入default-character-set=utf8mb4,如下:

[client]

default-character-set=utf8mb4

2、在[mysqld]字段里加入character-set-server=utf8mb4,如下:

[mysqld]

character-set-server=utf8mb4

3、在[mysql]字段里加入default-character-set=utf8mb4,如下:

[mysql]

default-character-set=utf8mb4

修改jdbc连接串的设置

jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=utf8

重启mysql

systemctl restart mysql

一般到这里已经可以了,如果还不行再按一下修改

修改database默认的字符集

ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;

修改table的字符集

ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 CO

LLATE utf8mb4_unicode_ci;

修改column默认的字符集

ALTER TABLE table_name CHANGE column_name column_name VARCHAR(191) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值