[ 永远的UNIX::UNIX技术资料的宝库 ]

首页 > 编程技术 > Php > 正文

解决PHP存取MySQL 4.1乱码问题

来源:不详 (2005-09-06 16:16:46)

 

从MySQL 4.1开始引入的多语言支持确实很棒,而且一些特性已经超过了其他的数据库系统。不过我在测试过程中发现使用适用于MySQL 4.1之前的PHP语句操作MySQL数据库会造成乱码,即使是设置过了表字符集也是如此。我读了一下新的MySQL在线手册中第十章"Character Set Support"后终于找到了解决方法并测试通过。

MySQL 4.1的字符集支持(Character Set Support)有两个方面:字符集(Character set)和排序方式(Collation)。对于字符集的支持细化到四个层次: 服务器(server),数据库(database),数据表(table)和连接(connection)。

查看系统的字符集和排序方式的设定可以通过下面的两条命令:

mysql> SHOW VARIABLES LIKE 'character_set_%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
7 rows in set (0.00 sec)

mysql> SHOW VARIABLES LIKE 'collation_%';
+----------------------+-------------------+
| Variable_name | Value |
+----------------------+-------------------+
| collation_connection | latin1_swedish_ci |
| collation_database | latin1_swedish_ci |
| collation_server | latin1_swedish_ci |
+----------------------+-------------------+
3 rows in set (0.00 sec)


上面列出的值就是系统的默认值。(很奇怪系统怎么默认是latin1的瑞典语排序方式)...

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

SET NAMES 'utf8';

它相当于下面的三句指令:
SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = utf8;

再试试看,正常了吧?^_^ Enjoy!


(http://www.fanqiang.com)



 相关文章
RedHat6.2服务器配置方案大全--第九,十,十一章Apache、Tomcat/JServ/php3/MySQL的整合 2001-09-29 08:05:01
MySQL的管理工具:phpMyAdmin 2002-03-26 08:02:00
Web服务器(四)Linux下Apache、php3、MySQL的整合 2002-02-20 06:15:00
php3:跨平台的服务器端嵌入式脚本语言(一) 2001-04-16 16:31:14
php3:跨平台的服务器端嵌入式脚本语言(二) 2001-04-16 16:32:53
PHP4手册:安装与设定(一) 2001-04-16 16:52:22
PHP4手册:安装与设定(二) 2001-04-16 16:53:02
PHP4手册:语法(一) 语法简述 2001-04-16 16:59:25
PHP4手册:语法(二) 常量与变量 2001-04-16 17:01:54
PHP4手册:语法(三) 运算符号 2001-04-16 17:06:04
PHP4手册:语法(四) 流程控制 2001-04-16 17:08:15
PHP4手册:语法(五) 函式与物件 2001-04-16 17:09:38
PHP4手册:函数库及函数(一) Adabas D 资料库连结函式库 2001-04-16 17:28:28
PHP4手册:函数库及函数(二) 阿帕契伺服器专用函式库 2001-04-16 17:32:27
PHP4手册:函数库及函数(三) 阵列处理函式库 2001-04-16 17:40:27
PHP4手册:函数库及函数(四) 拼字检查函式库 2001-04-16 17:44:00
PHP4手册:函数库及函数(五) BC 高精确度函式库 2001-04-17 09:27:59
PHP4手册:函数库及函数(六) 历法函式库 2001-04-17 09:33:12
PHP4手册:函数库及函数(七) 日期与时间函式库 2001-04-17 13:32:30
PHP4手册:函数库及函数(八) DBA 函式库 2001-04-18 11:21:08

★  感谢所有的作者为我们学习技术知识提供了一条捷径  ★
www.fanqiang.com