mysql个别文字乱码怎么办

76次阅读
没有评论

共计 1206 个字符,预计需要花费 4 分钟才能阅读完成。

自动写代码机器人,免费开通

丸趣 TV 小编给大家分享一下 mysql 个别文字乱码怎么办,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

mysql 个别文字乱码的解决方法:首先打开 server\MySQL 文件夹;然后打开 my.ini 文件;最后添加代码为“character_set_server=gbk”即可。

java 网站 MySQL 数据库个别文字乱码问题

乱码问题很让人头疼,特别是极其少量的乱码。这里分享一个个人开发过程中遇到的一个乱码问题,希望能对大家有所帮助。

方法 / 步骤

检查乱码出现位置——前台。

这里丸趣 TV 小编通过火狐浏览器的 firebug 工具检查了前台 jsp 页面,发现 post 的的确是 utf8 的数据。所以,排除前台传送数据时产生乱码。

检查乱码出现的位置——后台。

因为同事用来接收前台数据的是 struts formbean 的方式,所以丸趣 TV 小编不是很了解,就用了个笨办法:找到产生乱码的数据传递过程,对于过程中经过的每个方法都添加一个输出,在后台查看输出的数据。

结果,这些数据也是正常的。

检查乱码出现位置——MySQL 数据库。

当排除了前后台,那么只剩下数据库了。那么问题就在数据库上了。

丸趣 TV 小编先在数据库里直接数据了乱码的汉字,发现可以存储。排除了数据库表的文字编码问题。

之后丸趣 TV 小编在工具软件中查询了一下(语句:show variables like %char%),结果如下图。问题一下子发现了:由于 gb2312 中汉字并不全,所以一些汉字是没有编码的,此时这些汉字就会被强制转换为“?”,至此这个汉字的数据就丢失了,而且不可还原。

mysql 个别文字乱码怎么办

原因详解:

MySQL 数据库的数据进出实际上是有几道转换手续的。

其中进入的时候:character_set_client 转 character_set_connection 转 character_set_server 存入数据库。

而取出的时候:数据库取出转 character_set_server 转 character_set_result。

这样大家应该明白了吧,进出数据库的数据都要经过 character_set_server 转换,所以无论是前台的正确的汉字还是数据库内正确的汉字,只要不在 gb2312 内就会被转换成问号。

解决方法:

一劳永逸的方法,丸趣 TV 小编直接在 server\MySQL 文件夹内,将 my.ini 文件修改了。

修改过程为:找到 [mysqld] 再向下找几行发现“default_character_set=utf8”,在该行下添加一行“character_set_server=gbk”。

当然不是必须用 gbk,丸趣 TV 小编是为了小心起见用了国标扩展,即 gb2312 的扩展 gbk。

看完了这篇文章,相信你对 mysql 个别文字乱码怎么办有了一定的了解,想了解更多相关知识,欢迎关注丸趣 TV 行业资讯频道,感谢各位的阅读!

向 AI 问一下细节

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-18发表,共计1206字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)