一:异常信息:errorCode:1366
Caused by: java.sql.SQLException: Incorrect string value: '\xE7\xAE...' for column 'description' at row 1
二:异常原因:字符集冲突
mysql insert入库的时候,由于插入数据编码与数据库字段字符集不一致,导致数据无法插入。
三:追本溯源
在mysql数据库中执行show character set,可以看到不同的字符集的最大长度不同。
如果执插入utf8编码数据,数据库表中字段字符集是latin。(查询字段字符集方法:show full columns from user;)
如果最大长度为3的utf8字符集存储到最大长度为1的latin数据库字段中,数据会被截断,无法正常插入,导致异常。
四:解决办法
修改数据库的字符集编码
MySQL配置文件在Windows下叫my.ini,在MySQL的安装根目录下;在Linux下叫my.cnf,该文件位于/etc/my.cnf。
(1)window服务器
mysql数据库的配置文件my.ini,此文件放在mysql根目录下。在此文件下查找default-character-set属性,并将其值更改为utf8:default-character-set = utf8
(2)linux服务器default-character-set=utf8
在新的版本5.5以上,如果这样修改的话,会造成无法启动的错误,经过查看mysql日志,如下:
是default-character-set参数不可用。给定一系列字符并赋予对应的编码后,所有这些字符和编码对组成的集合就是字符集(Character Set)。例如,给定字符列表为{'A','B'}时,{'A'=>0, 'B'=>1}就是一个字符集;
(2)字符序(Collation)是指在同一字符集内字符之间的比较规则;MySQL中的字符序名称遵从命名惯例:以字符序对应的字符集名称开头;以_ci(表示大小写不敏感)、_cs(表示大小写敏感)或_bin(表示按编码值比较)结尾。例如:在字符序``utf8_general_ci''下,字符``a''和``A''是等价的;
(3)MySQL字符集设置