解决MySQL乱码,并不难


  本文标签:MySQL乱码

  我们曾在前一些文章对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 文件)

  

  1. # CLIENT SECTION  
  2. [client]  
  3. port=3306 
  4. [MySQL]  
  5. default-character-set=gbk 
  6. # SERVER SECTION  
  7. [MySQLd]  
  8. default-character-set=gbk   

  

  (2)修改data目录中相应数据库目录下的db.opt配置文件

  

  1. default-character-set=gbk 
  2. 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)在创建数据库时指定字符集

  

  1. create database yourDB CHARACTER SET gbk; 

  (5)在dos命令上要设置

  

  1. set names gbk 

  好了,经过检查上面四个方面的设置,应该 OK 了!不会出现诸如

  com.MySQL.jdbc.MySQLDataTruncation: Data truncation: Data too long for column等问题.