当前位置:Gxlcms > mysql > MySQL中文乱码具体解决方案

MySQL中文乱码具体解决方案

时间:2021-07-01 10:21:17 帮助过:2人阅读

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

人气教程排行