本文主要是介绍MySQL java.sql.SQLException: Incorrect string value,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
环境
Java:1.8
MySQL:5.7.18
前言
调用接口时,报了个这样的错误:
java.sql.SQLException: Incorrect string value: '\xE8\xB4\xA6\xE6\x88\xB7...' for column 'accountName' at row 1
查阅后,知道是字符编码问题造成的;
解决
知道原因后,对面表右键选择设计表
- 选项
- 默认字符集
:
之后再试接口,发现错误依然存在;
网上基本都是告诉你如下操作:
在mysql的安装目录下有一个文件叫做my.ini。
在其中添加两句:
[mysqld]
character-set-server=utf8mb4
[mysql]
default-character-set=utf8mb4
然后进行重启。
重启之后再次来到创建的那张表,执行语句:
alter table TABLE_NAME convert to character set utf8mb4 collate utf8mb4_bin; (将TABLE_NAME替换成你的表名)
但是呢?在我目前的公司,我可以操作数据库,可以增删表,但是我没办法重启数据库,也没有权限去修改my.ini
文件,因为被devops
统一管理着。
我好奇的是,表已经设置为utf8mb4
了,为什么还是报错,后来我在表里写中文试试,结果却是???
:
查阅资料得知到:
为什么都改了utf8mb4还是不行呢?这个错误主要是对mysql的字符集了解的不够全面。mysql的字符集的作用域有三个层级一个数据库级,一个是表级,一个是列级(字段级别的)。优先级是:列级》表级》数据库级。
接着我们进行如下操作:
查看数据库字符集
show variables like '%character%';
查看列的字符集
show full columns from patientwithdrawapplication
可以看出 列的字符集 依然不对
修改列的字符集
alter table patientwithdrawapplication MODIFY bankCity varchar(50) charset utf8mb4;
修改后的结果
最后一点总结:
对于mysql字符集我们不想出现乱码情况有一个经验就是character_set_client、character_set_connection、character_set_results字符尽量设置成一致的。
set names utf8mb4
这条语句等同于对上面三个参数的配置成utf8mb4。在插入和查询emoji字符的时候,不要忘了在前面加上这个语句,以防止出现乱码。
刚开始,我以为只需要执行:
set names utf8mb4
就可以了,对于列而言,还是不行,还是需要执行这样的命令才能修改:
alter table patientwithdrawapplication MODIFY bankCity varchar(50) charset utf8mb4;
参考地址:
mysql设置了字符集utf8mb4依然无法插入emoji字符
这篇关于MySQL java.sql.SQLException: Incorrect string value的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!