我在虚拟机上安装了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
相关推荐
### RedHat 5 下 MySQL 5.6 的安装与简单维护 #### 一、环境准备与软件需求 在开始之前,我们需要确保以下条件得到满足: 1. **操作系统**:RedHat 5 操作系统。 2. **软件包**:MySQL 5.6 的 RPM 包。包括但不...
在Linux RedHat环境下安装MySQL是一项基础且重要的任务,尤其对于那些需要在服务器上部署数据库服务的开发者和系统管理员来说。MySQL是一种广泛使用的开源关系型数据库管理系统(RDBMS),它以其高效、稳定和易于...
在Red Hat Enterprise Linux 5环境下部署MySQL集群,可以确保数据的冗余和故障切换能力,提高系统的整体稳定性。 首先,我们来看一下MySQL集群的基本组件: 1. **管理节点(NDB Management Node, ndb_mgm)**:负责...
在安装Redhat Linux之后,经常遇到的一个问题是中文显示出现乱码问题。这不仅影响用户体验,还可能导致一些功能无法正常使用。本文将详细介绍如何全面解决这一问题,并确保系统中的命令行能够正确显示中文。 #### ...
RedHat 7.9 安装 MySQL 8.0 MGR RedHat 7.9 安装 MySQL 8.0 MGR 是一种高可用性的数据库解决方案,它可以提供高性能、可扩展性和高可用性的数据库服务。在本文中,我们将指导您如何在 RedHat 7.9 上安装 MySQL 8.0 ...
在Red Hat Enterprise Linux 5操作系统中,用户可能会遇到中文显示乱码的问题,这通常是由于系统缺少支持中文字符集的字体或者配置不正确导致的。在本文中,我们将深入探讨这个问题并提供一种有效的解决方案。 首先...
在Redhat系统上安装MySQL 5.5是一个涉及多个步骤的过程,这包括配置环境、下载安装包、编译源码以及设置数据库参数等。在这个过程中,`my.cnf`文件扮演着至关重要的角色,它是MySQL服务器的主要配置文件,用于定制...
#### 知识点一:Redhat Linux系统中文乱码问题概述 在使用Redhat Linux系统时,经常会出现中文显示为乱码的情况,这主要是由于系统的语言环境设置不正确或者缺少相应的中文字体支持所导致的。中文乱码不仅影响用户...
超详细的操作步骤, 在Redhat linux 7.5版本中安装 mysql 5.6版本的数据库. 1 卸载已有mysql, 使用yum(附带yum源的设置步骤)安装依赖 2 下载mysql 5.6文件 3 上传文件到linux 4 安装rpm包 5 设置可远程连接 6 ...
本文将详细阐述如何在Red Hat Enterprise Linux 5(简称Redhat5)上安装MySQL数据库系统,重点是利用提供的两个 RPM 包——MySQL-server-community-5.1.62-1.rhel5.i386.rpm 和 MySQL-client-community-5.1.62-1....
在IT行业中,操作系统是开发和工作的重要平台,而Red Hat作为一款广受欢迎的企业级Linux发行版,有时会遇到中文字符显示不正常,即中文乱码的问题。这个问题对程序员和其他需要处理中文内容的用户来说确实非常棘手。...
以上就是在RHEL5.5环境下安装、配置MySQL数据库的基本步骤和一些基本操作。请注意,实际操作时应根据实际情况调整命令中的路径和参数,以确保安装成功。此外,安全性和性能优化也是数据库管理的重要方面,需要额外...
在Linux的Red Hat版本上,MySQL数据库系统可能会遇到字符乱码的问题,这通常是由于默认的字符集设置不支持中文或者其他非ASCII字符导致的。解决这个问题需要对MySQL的配置进行一些调整,以确保它能正确地处理和显示...
以上就是RedHat 5.4 Linux系统下安装MySQL5.0的详细步骤。这个过程涵盖了从源代码的获取到数据库的初始化,再到权限配置和服务管理,是安装MySQL服务器的基础操作。在实际应用中,可能还需要考虑其他因素,如日志...
在RedHat 6.3上彻底卸载自带的MySQL涉及到多个步骤,包括检查已安装的MySQL组件、按顺序卸载这些组件,并解决可能出现的依赖问题。正确地执行上述步骤能够确保MySQL被安全地卸载,同时不会影响系统的其他部分。这...
### Linux Redhat5下手工安装配置PHP+MySQL+Apache -- LAMP环境搭建 本文将详细介绍如何在Redhat5系统上手动搭建LAMP(Linux + Apache + MySQL + PHP)环境。LAMP是一种流行的开源Web服务器软件堆栈组合,适用于...
### Linux RedHat 下安装 MySQL 步骤详解 #### 一、前言 在 Linux RedHat 系统上安装 MySQL 数据库是一项常见的系统管理任务。本文将详细介绍如何在 RedHat 系统上安装 MySQL,并覆盖安装前的准备、安装过程、验证...