我们曾在前一些文章对MySQL乱码的实际解决方案有一些相关的介绍,我们今天主要向大家描述的是MySQL乱码处理的经验总结,以及实际的解决办法,以下就是对其具体内容的分析,望你会有所收获。
MySQL乱码处理总结:
(1)java中处理中文字符正常,在cmd client中显示乱码是字符集的问题.
(2)字段长度设置够长,但插入中文字符时提示com.MySQL.jdbc.MySQLDataTruncation: Data truncation: Data too long for column错误是字符集的问题.
(3)乱码问题归根到底是字符集的问题,那就从字符集设置方面考虑,不外乎下面几个方面:server,client,database,connection,results.
解决办法
(1)修改 my.ini(MySQL Server Instance Configuration 文件)
# CLIENT SECTION [client] port=3306 [MySQL] default-character-set=gbk # SERVER SECTION [MySQLd] default-character-set=gbk
(2)修改data目录中相应数据库目录下的db.opt配置文件
default-character-set=gbk default-collation=gbk_chinese_ci
(3)数据库连接串中指定字符集 URL=jdbc:MySQL://yourIP/college user=root&password=yourPassword&useUnicode=true&characterEncoding=gbk 注:在MySQL4.1.0版 要加useUnicode=true&characterEncoding=gbk 如果是5.0版以上的,加不加都是没有关系的! (4)在创建数据库时指定字符集 create database yourDB CHARACTER SET gbk;
(5)在dos命令上要设置 set names gbk
好了,经过检查上面四个方面的设置,应该 OK 了!不会出现诸如 com.MySQL.jdbc.MySQLDataTruncation: Data truncation: Data too long for column等问题.