当前位置: 首页 > 图文教程 > 数据库 > MYSQL > MySQL字符集:保证不发生乱码的方法

MYSQL
教你如何编写高效的MySQL数据库应用
解析MySQL数据库是如何对抗解密高手
MySQL常见问题集锦解答及技巧
透视MySQL数据库之更新语句
MYSQL的操作类(已封装)
windows环境下mysql数据库的主从同步备份步骤
优化MySQL数据库性能的八大“妙手”
安装与卸载MySQL系统服务(常见问题)
在SQL Server中快速删除重复记录
教你用Myisamchk进行崩溃恢复MySQL
再谈MySQL数据库备份恢复和乱码问题
一个MySQL数据备份/恢复的简易方法
教你如何将MySQL数据库的密码恢复
MySQL数据库中双机热备配置份过程
关于MySQL数据库基本调度策略的简介
让MySQL数据库自动恢复的具体操作
MySQL加强对PHP的支持--mysqlnd_php6
MYSQL初学者使用指南(下篇)
MYSQL初学者使用指南(上篇)
mysql中的替换语句

MYSQL 中的 MySQL字符集:保证不发生乱码的方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 39 ::
收藏到网摘: n/a

数据库中关于字符集的种类有很多,对编程有影响的主要是客户端字符集和数据库字符集(还有一个服务器字符集,不知道干什么用的)。

数据库中常用的操作就是保存数据和读取数据,在这过程中,乱不乱码和数据库字符集貌似没有什么关系。我们只要保证写入时选择的字符集和读取时选择的字符集一致,即只需保证两次操作的客户端字符集一致即可。

客户端字符集的设置,依据客户端不同方法不同:

1. 使用控制台连接,在my.ini文件中的client项里面设置;

2. 使用ems连接,优先使用ems连接配置的字符集,默认使用my.ini文件中的设置;

3. jdbc连接,在连接串中指定:

jdbc:mysql://192.168.3.99:3306/test?useUnicode=true&;characterEncoding=gbk

在写入时Mysq会将客户端指定的字符集转换成数据库字符集存入数据文件,读取时又将数据库字符集转换成客户端指定的字符集展示给客户端,把客户端字符集和数据库字符设置一致,显而易见的好处是免掉转换的性能损耗;另外,如果考虑到以后数据库的迁移,将数据库字符集设置为大多数数据库都支持的字符集会省掉很大麻烦。

几个字符集相关的命令:

1. 查看 MySQL 数据库服务器字符集,数据库字符集和客户端字符集

以下为引用的内容:

  show variables like ’%char%’;

  character_set_client,客户端字符集

  character_set_database,数据库字符集

  character_set_server,服务器字符集

  2. 查看 MySQL 数据表(table) 的字符集

  show table status from tablename like ’%countries%’;

  3. 查看 MySQL 数据列(column)的字符集。

  show full columns from tablename;

  4. 查看当前安装的 MySQL 所支持的字符集。

  show char set;