`
cuisuqiang
  • 浏览: 3970221 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
3feb66c0-2fb6-35ff-968a-5f5ec10ada43
Java研发技术指南
浏览量:3678322
社区版块
存档分类
最新评论

Redhat5下MySql遇到的乱码问题

阅读更多

我在虚拟机上安装了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

 

1
1
分享到:
评论
2 楼 cuisuqiang 2012-10-31  
设置mysql帐号
           mysql安装后默认生成两个帐号:一个是root,未设置密码,可以从本机登录到mysql;另一个是匿名帐号,无帐号名、无密码,可以从本机登录,未提供用户名的连接都将假定为此帐号。这样的设置存在着安全隐患,按下面的步骤进行更改。
           以root帐号连接到mysql服务器:
           mysql -u root
           如果提示找不到mysql文件,请尝试使用绝对路径,如本文示例为:
           /usr/local/mysql/bin/mysql -u root
           命令成功执行后将进入到mysql命令提示符下:
           mysql>
           (以下命令均在mysql命令提示符下执行)
           改变当前数据库为mysql:
           use mysql
           设置从本地主机登录的root帐号密码:
           set password for root@localhost=password('your password');
           或:
           update user set password=password('your password') where user='root' and host='localhost';
           删除匿名帐号:
           delete from user where user='' ;
           删除密码为空的帐号:
           delete from user where password='';
           删除允许非localhost主机登录的帐号:
           delete from user where host<>'localhost' ;
           执行下面的命令使更改生效:
           flush privileges ;
           执行下面的命令退出mysql命令行:
           quit
           或:
           /q
1 楼 cuisuqiang 2012-03-20  
关于JDBC访问mysql的一个例子可以看:http://cuisuqiang.iteye.com/blog/1458557

相关推荐

    Linux redhat桌面命令中文乱码解决

    在安装Redhat Linux之后,经常遇到的一个问题是中文显示出现乱码问题。这不仅影响用户体验,还可能导致一些功能无法正常使用。本文将详细介绍如何全面解决这一问题,并确保系统中的命令行能够正确显示中文。 #### ...

    解决linux的redhat版上mysql字符乱码的问题

    在Linux的Red Hat版本上,MySQL数据库系统可能会遇到字符乱码的问题,这通常是由于默认的字符集设置不支持中文或者其他非ASCII字符导致的。解决这个问题需要对MySQL的配置进行一些调整,以确保它能正确地处理和显示...

    Oracle通过DBlink连接MySQL

    在实际操作中,务必注意字符集的匹配,避免因字符集不一致导致的数据乱码问题。此外,安全也是重要的考虑因素,确保敏感信息如用户名和密码的安全存储。在整个配置过程中,每一步都需要仔细检查和测试,确保每个环节...

    RedHat-Linux上部署javaweb项目.doc

    在Linux环境下,MySQL的安装路径通常是`/home/mysql/mysql5.0.87`,要启动MySQL服务,可以使用`# bin/mysqld_safe --user=mysql &`。然后,使用`# mysql –u root –p`登录数据库,并执行SQL脚本(如`AiWang.sql`)...

    Oracle_10g_RAC_For_Redhat_AS_4安装指南

    - **解决乱码问题**:如果出现乱码问题,可以通过修改 `/etc/sysconfig/i18n` 文件中的 `LANG` 值为 "en_US.UTF-8" 来解决。这将消除乱码,但可能导致中文无法正常显示。 #### 第二部分:为 Oracle RAC 安装 Redhat...

    linux下redmine安装及常见问题faq

    【Redmine在Linux下的安装与常见问题】 Redmine是一款开源的项目管理软件,适用于团队协作和任务跟踪。...然而,每个系统可能存在特定的配置差异,因此遇到问题时,查阅官方文档或社区支持是非常有帮助的。

    Redhat Linux服务器配置实务.doc

    - 错误处理:列出并解决常见的权限、找不到资源、类找不到、授权错误和中文乱码问题。 在进行这些配置时,注意每一步都要根据实际情况进行调整,如防火墙设置、安全策略和性能优化等。同时,定期备份数据和配置,...

    cacti中文版安装配置

    - 创建名为`cacti`的数据库,并设置字符集为UTF-8,防止出现乱码问题。 ```sql CREATE DATABASE cacti DEFAULT CHARACTER SET utf8; GRANT ALL PRIVILEGES ON cacti.* TO 'cacti'@'localhost' IDENTIFIED BY '...

    使用vsftpd架设FTP服务器

    2. **启用ASCII传输方式**:设置`ascii_upload_enable=YES`和`ascii_download_enable=YES`,以便在传输文本文件时自动转换编码格式,避免乱码问题。 3. **设置欢迎信息**:通过`welcome_file=/etc/vsftpd/welcome....

Global site tag (gtag.js) - Google Analytics