Linux系统下MYSQL数据库中文数据乱码问题

Linux系统下MYSQL数据库中文数据乱码问题,第1张

根据你的问题,数据库不在自己手边。

那首先要调查清楚,数据表的编码,看清,不是数据库,是表,表的字符集编码。

然后往前顺。

然后再java程序中转码,保证写到sql中的数据是以该数据表所用的字符集编码的就好了。

乱码出现在不同部分的通信之间

一个系统中,通常是在显式输入中文的地方发生转码错误。

比如,servlet处理从浏览器传来的数据的时候,

从资源文件读取数据的时候。

在程序中显式地硬编码字符串中文字面值的时候。

从别人的数据库读取数据的时候。

这些地方经常会跟之后的系统编码不一致,所以在这些地方使用字符串数据的时候,就要转码。

资源文件,可以用文本工具保存成需要的编码。

对于request中的数据,可以在正式处理之前加

过滤器。

对于别的数据库,可以设一个专门的过滤类来转码。

如果是图形界面下的虚拟终端,设置(根据不同的 shell 修改不同的环境参数配置文件,如 bash 就修改 .bashrc 文件或 .bash_profile 文件)

1

export LANG=zh_CN.UTF-8

如果是远程登录(比如使用 ssh 登录),则根据你的客户端的环境进行设置,一个可能的方案是:

1

export LANG=zh_CN.GB18030

locale 看看你的当前是什么语言显示然后

1

vi /etc/sysconfig/<a href="https://www.baidu.com/s?wd=i18n&tn=44039180_cpr&fenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1YvPAfsPARvmHRdPHcdnjTL0ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EPjnzPHD4nW0zPH6zPjbzrj6Y" target="_blank" class="baidu-highlight">i18n</a>

一般情况下linux服务器都是配置utf-8,不使用中文的。

用命令

show

variables

like

"%char%"

看你的

character_set_system

这一项是什么字符集,然后在my.cnf中把default-character-set

=

这个字符集

就可以了,,,不过以前的

乱码

还是照样乱,以后的就可以显示了。。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9537717.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存