MariaDB社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 4351|回复: 2
打印 上一主题 下一主题

[字符集] MySQL字符集:保证不发生乱码的方法

[复制链接]
跳转到指定楼层
1#
发表于 2008-8-18 11:42:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
作者: Egbert

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

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

  客户端字符集的设置,依据客户端不同方法不同:
  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;
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享 分享淘帖 顶 踩
2#
发表于 2009-4-22 19:51:29 | 只看该作者
学习了,不是很懂,刚学。
3#
发表于 2009-8-14 17:57:22 | 只看该作者
不是很懂,但又学了点有关字符集的知识.
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|手机版|MariaDB社区 ( 京ICP备07012489号    |
业务联系: QQ:48474881; 邮箱: 48474881@qq.com; 电话:13911732319
声明:本站部分文章是网友转载,若未经作者同意或署名有误,请联系网站管理员。

GMT+8, 2024-11-10 07:26 , Processed in 0.058308 second(s), 19 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表