WEB开发网
开发学院数据库MySQL MySQL字符集 阅读

MySQL字符集

 2008-09-05 11:08:06 来源:WEB开发网   
核心提示: 使用 mysql> SHOW VARIABLES LIKE 'character%';查看,发现数据库编码均已改成utf8+--+-+|Variable_name|Value|+--+-+|character_set_client|utf8||character_se

使用 mysql> SHOW VARIABLES LIKE 'character%';查看,发现数据库编码均已改成utf8 

   +--------------------------+---------------------------------+
  |Variable_name|Value|
  +--------------------------+---------------------------------+
  |character_set_client|utf8|
  |character_set_connection|utf8|
  |character_set_database|utf8|
  |character_set_filesystem|binary|
  |character_set_results|utf8|
  |character_set_server|utf8|
  |character_set_system|utf8|
  |character_sets_dir|D:"mysql-5.0.37"share"charsets"|
  +--------------------------+---------------------------------+

(2) 还有一种修改字符集的方法,就是使用mysql的命令

   mysql>SETcharacter_set_client=utf8;
  mysql>SETcharacter_set_connection=utf8;
  mysql>SETcharacter_set_database=utf8;
  mysql>SETcharacter_set_results=utf8;
  mysql>SETcharacter_set_server=utf8;
  mysql>SETcollation_connection=utf8;
  mysql>SETcollation_database=utf8;
  mysql>SETcollation_server=utf8;

一般就算设置了表的默认字符集为utf8并且通过UTF-8编码发送查询,你会发现存入数据库的仍然是乱码。问题就出在这个connection连接层上。解决方法是在发送查询前执行一下下面这句: 

  SETNAMES'utf8';

它相当于下面的三句指令:

   SETcharacter_set_client=utf8;
  SETcharacter_set_results=utf8;
  SETcharacter_set_connection=utf8;

总结:

因此,使用什么数据库版本,不管是3.x,还是4.0.x还是4.1.x,其实对我们来说不重要,重要的有二:

1) 正确的设定数据库编码.MySQL4.0以下版本的字符集总是默认ISO8859-1,MySQL4.1在安装的时候会让你选择。如果你准备使用UTF- 8,那么在创建数据库的时候就要指定好UTF-8(创建好以后也可以改,4.1以上版本还可以单独指定表的字符集)。

2) 正确的设定数据库connection编码.设置好数据库的编码后,在连接数据库时候,应该指定connection的编码,比如使用jdbc连接时,指定连接为utf8方式。

上一页  1 2 3 

Tags:MySQL 字符集

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接