解决MySQL中文乱码的好用方案大汇总

数据库 MySQL
此文章主要是分析MySQL中文乱码的产生原因以及对MySQL中文乱码的实际解决方案的描述,以下就是文章的主要内容描述。

以下的文章主要介绍的是解决MySQL中文乱码的好用方案大汇总,我们大家都知道在使用MySQL数据库时,在插入中文字符的实际操作过程中,有时会出现一些乱码,例如,中文全被用?代替。

出现这种情况的原因,多是字符集不匹配造成的。

在MySQL中,如果使用缺省的字符集,在建库、建表时,默认使用的是latin1字符集,为ISO 8859-1西欧字符集。

插入中文字符时,与之不匹配,就会出现乱码。

本人使用的是MySQL 5.0版,并用C#操作MYSQL数据库,当插入中文字符时,发现显示的是MySQL中文乱码。

初步估计是字符集没有配对。查找后,发现MSYQL默认使用的是latin1,因此将数据库的配置文件中的字符设置改为utf8,并在C#中将中文字符,转为utf8,插入后,仍为乱码。

MySQL也支持gb2312,又将MySQL的字符设置改为gb2312,C#中使用Default,重起MySQL后,操作仍然无效。

后想起,虽然将MySQL的字符集设置为gb2312或utf8,但已经建立的数据库和表,仍采用的是默认的字符集,也即仍为当初的西欧字符集,***,只得忍痛将数据库删除,重新以gb2312字符集建立数据库和表。

再用C#插入中文字符后,一切OK。

再安装好MySQL后,可以手工或使用配置工具,将my.ini文件中的默认字符集改为gb2312,再重新建库和表时,不用再在语句中指定字符集,其默认设置也即为gb2312,可以正常显示中文字符集。

1.建立数据库是一般的语句:

  1. create database dbname; 

2.在库中建表时语句为:

  1. create table tbname(..........)engine=MyISAM character set gbk collate gbk_chinese_ci; 

3.程序中连接数据库的Connection对象需要写成

  1. Connection con = DriverManaager.getConnection("jdbc:mysql://...user=..&password=...&useUnicode=true&characterEncoding=gbk"); 

4.若在终端下用mysql命令向数据库插入数据,则在进入mysql时的命令写成:

  1. #mysql --default-character-set=gbk -u ... -p 

5.在jsp页面的编码设置为utf-8.

我找到一个方法好像可以MySQL中文乱码解决这个问题了

在安装mysql server的时候,无论是选择gb2312还是utf-8,都没有关系,这些字符集在phpMyAdmin中都可以很好的工作,主要是自己的脚本要正确的显示中文,可以在php脚本中,连接数据库之后,正式的数据查询提交之前执行下面的语句:

$SetCharacterSetSql = "SET NAMES '自己使用的字符集'";

 

  1. $Recordset1 = mysql_query($SetCharacterSetSql, $conn_Resource) or die(mysql_error()); 

然后再执行自己的查询语句,得到的结果就是正确的了。刚刚试了gb2312和utf-8,都没有问题。以上的相关内容就是对MySQL中文乱码解决方案集锦的介绍,望你能有所收获。

 

责任编辑:佚名 来源: 博客园
相关推荐

2010-05-17 14:49:43

MySQL中文乱码

2010-05-12 16:47:54

MySQL 中文乱码

2011-12-21 14:46:26

JavaJFreeChart

2010-05-31 18:33:00

MySQL中文乱码

2010-05-20 10:00:58

MySQL 中文乱码

2010-05-14 17:27:40

MySQL中文乱码

2010-05-19 15:59:30

MySQL 中文乱码

2024-11-08 13:47:35

中文乱码配置

2010-05-17 09:49:46

MySQL中文问题

2010-06-02 16:36:38

连接MySQL中文乱码

2011-08-08 10:29:12

MySQL

2010-05-17 14:36:11

2010-05-14 10:05:17

MySQL中文乱码

2010-05-17 14:17:25

MySQL pytho

2009-07-24 11:24:33

ASP.NET中文乱码

2010-05-25 18:12:19

MySQL 安装

2010-05-24 11:17:41

MySQL数据库

2010-11-09 17:09:23

SQL Server中

2009-07-02 13:32:56

JSP中文乱码

2011-02-24 10:48:51

FireFTP
点赞
收藏

51CTO技术栈公众号