欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

MySQL中文乱码具体解决方案

程序员文章站 2022-06-11 12:02:22
...

以下的文章主要介绍的是MySQL中文乱码的解决,MySQL中文乱码在实际的应用中是经常出现,导致实际的运行中产生很多的不便,以下的文章就是介绍MySQL中文乱码的解决方案。望你能有所收获。 原来常常在群里看到MySQL的乱码问题,但是由于本人一直在用oracle和sq

以下的文章主要介绍的是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中文乱码解决了。