MySQL中文乱码具体解决方案


  本文标签:MySQL中文乱码

  以下的文章主要介绍的是MySQL中文乱码的解决,MySQL中文乱码在实际的应用中是经常出现,导致实际的运行中产生很多的不便,以下的文章就是介绍MySQL中文乱码的解决方案  。望你能有所收获  。

  原来常常在群里看到MySQL的乱码问题,但是由于本人一直在用oracle和sql server所以没多在乎,昨天用了用MySQL结果就遇到了传说中的乱码…..  。现在我们来讲讲MySQL的乱码问题  。首先你进入的你MySQL

  

  用show variables查看

  

  

  这里可以查看到你的字符集,character_set_server是服务器编码  。现在我们默认的是latin1要改变服务器的编码必须重新启动服务器,我们先用MySQLadmin –uroot shutdown关闭服务器,然后MySQLd –C GBK启动服务器 –C是character_set_server的一个简写(可以也可以写成MySQLd –character_set_server gbk).这样修改以后我们再进入MySQL查看就会显示:

  

  这样我们就把服务器和数据库的编码改为了GBK  。

  现在我们就可以插入中文字符串了,但是为什么有时间还是会显示

  

  

  1. Exception in thread "main" com.MySQL.jdbc.MySQLDataTruncation: 

      

    Data truncation: Data too long for column name at row 1 

  

  MySQL中文乱码解决中出现上述情况,这是因为你只是修改了MySQL的服务器的字符编码,并没有修改已经有数据库的编码,这时候你需要手动的把data目录下的数据库中的db.opt中的编码改为

  

  1. default-character-set=gbk 
  2. default-collation=gbk_chinese_ci 

  

  这样修改以后你在重启服务器就可以插入中文了  。

  

  但是这时候还有个问题就是在你应用程序当中显示的是中文字符,但是在命令窗口还是乱码  。

  

  这时候你注意我们上面图中的character_set_client字符还是latin1当然显示的是乱码咯哟  。所以你进入MySQL客户端程序的时候因该把客户端默认的编码改为gbk才能显示正常  。

  

  你可以在MySQL里修改,也可以在登陆的时候MySQL –uroot –default-character-set=gbk修改

  

  如此以来就解决了MySQL中文乱码解决了  。