我在虚拟机上安装了redhat并安装了mysql数据库,并在本地通过java访问,直接使用jdbc访问。
后来发现当数据库存储汉字时存在乱码问题,随后在网上找资料进行解决,现在问题已经解决,来总结一下乱码的几个问题。
更改数据库默认字符集编码:
更改mysql配置文件,这个配置文件在/etc/my.cnf,可能安装mysql后这个文件就有了,如果没有,请回到根目录然后查询cnf文件:
find / -iname '*.cnf' -print
拷贝 small.cnf、my-medium.cnf、my-huge.cnf、my-innodb-heavy-4G.cnf其中的一个到/etc下,改名为my.cnf:
cp /usr/share/mysql/my-medium.cnf /etc/my.cnf
拷贝路径根据查询出来的结果修改。
修改my.cnf
vi /etc/my.cnf
在[client]下添加
default-character-set=gbk
在[mysqld]下添加
default-character-set=gbk
然后重启mysql。
登录mysql查询是否生效:
mysql> show variables like 'collation_%'; mysql> show variables like 'character_set_%';
注意如果你设置的是UTF-8请设置utf8,而不是utf-8,否则你的mysql重启时不能启动。
修改数据库字符集后再修改数据库的字符集:
mysql>use mydb mysql>alter database mydb character set gbk;
建议是在创建数据库时就指定字符集
mysql>create database mydb character set gbk;
除了使用命令来修改数据的字符集,也可以修改其配置文件
修改 /var/lib/mysql/mydb/db.opt
default-character-set=latin1 default-collation=latin1_swedish_ci
为
default-character-set=gbk default-collation=gbk_general_ci
重起MySQL
建表时注意:
除了修改mysql和其数据库的字符集外,要注意建表时你可能用的是导出的SQL语句,这些语句中可能包含了建表的字符集,一定要修改或删除这些语句:
CREATE TABLE `NewTable` ( `id` int(11) NOT NULL , `name` varchar(50) CHARACTER SET latin1 COLLATE latin1_swedish_ci NULL DEFAULT NULL , `age` int(100) NULL DEFAULT NULL , PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARACTER SET=gbk COLLATE=gbk_chinese_ci CHECKSUM=0 ROW_FORMAT=DYNAMIC DELAY_KEY_WRITE=0 ;
连接方面:
如果数据库配置正确,那么使用管理工具如Navicat for MySQL时就不会有问题了,但是在程序中难免还是有问题。
除了对于数据库方面的注意外,在连接数据库要注意指定连接的字符集
jdbc:mysql://192.168.154.128:3306/t2?useUnicode=true&characterEncoding=gbk
程序方面:
可是就算到这里仍然可能是乱码,但是没有那么严重了,这就要你在代码中进行转换了。
String newStr = new String(s.getBytes("ISO-8859-1"),"GBK");
也许有人会说,乱码就是乱码,还严重不严重?其实乱码在我看来分为两种情况,一种就是存储或者其他方面乱了,而另一种是存储是对的但是显示有问题。比如你设置正确后使用管理工具没有问题但是程序读取就有问题。
如果你看到的乱码是根本不知道显示的是什么,那就是严重的。但如果你看到的是????那在我看来就是缺少转换,就不属于大问题。当然这是个人看法,请大家不要钻牛角尖。
请您到ITEYE看我的原创:http://cuisuqiang.iteye.com
或支持我的个人博客,地址:http://www.javacui.com
相关推荐
RedHat5下mysql集群
RedHat下安装mysql,并附上一小段C测试程序,测试是否可用。
redhat5下mysql5.6的安装与简单维护,希望大家喜欢!
redhat5.5下MySql数据库的安装配置及简单操作
装了Red Hat Enterprise Linux 5之后会有一个问题,那就是中文乱码问题,在此我和大家分享下问题的解决方法
下面小编就为大家带来一篇解决linux的redhat版上mysql字符乱码的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
NULL 博文链接:https://my5622576.iteye.com/blog/411224
RedHat 7.9安装MySQL 8.0 MGR
全面解决 安装Linux后 中文乱码 命令行 解决方案
超详细的操作步骤, 在Redhat linux 7.5版本中安装 mysql 5.6版本的数据库. 1 卸载已有mysql, 使用yum(附带yum源的设置步骤)安装依赖 2 下载mysql 5.6文件 3 上传文件到linux 4 安装rpm包 5 设置可远程连接 6 ...
redhat 下mysql的安装和操作命令
redhat enterprise linux5 mysql安装文件
redhat enterprise 4加挂u盘过程及汉字乱码问题解决方案redhat enterprise 4加挂u盘过程及汉字乱码问题解决方案redhat enterprise 4加挂u盘过程及汉字乱码问题解决方案redhat enterprise 4加挂u盘过程及汉字乱码问题...
Linux RedHat 下安装MYSQL步骤
redhat安装mysql5.0.45详细步骤。
redhat linux 中文乱码解决方法
经过了大量查阅资料,我总结出如何卸载redhat自带的mysql,有图有真相
安装mysql5.7 卸载默认mariadb rpm–qa| grep mairadb rpm–e –nodepsmariadb-libs-5.5.56-2.el7.x86_64 下载软件并上传到服务器 安装 –vxfmysql-5.7.20-1.el7.x86_64.rpm-bundle.tar rpm ...
redhat下mysql热备制作,参考高性能mysql一书编写的,测试通过,包含截图等
redhat5下安装mysql+apache2+php+vsftp+svn