PHP+MYSQL中文乱码问题 |
本文标签:php,mysql,中文乱码 从MySQL 4.1开始引入多语言的支持,但是用PHP插入的中文会出现乱码.无论用什么编码也不行. 解决这个问题其实很简单. 1.在建表的时候设置编码类型为gb2312_chinese_ci. 2.在PHP页面的数据库连接语句加一行mysql_query("SET NAMES gb2312",$link); 例如 $db_host="localhost"; $db_user="root"; $db_password="password"; $db_name="test"; $link=mysql_connect($db_host,$db_user,$db_password); mysql_query("SET NAMES gb2312",$link); $db=mysql_select_db($db_name,$link); $query="select * from user"; $result=mysql_query($query); 写入页面和读取页面都加入这行.这样在MYSQL里面的中文就能正常显示了. 相关资料: 从MySQL 4.1开始引入多语言的支持,而且一些特性已经超过了其他的数据库系统 。 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的瑞典语排序方式)... 复制代码 代码如下: set character_set_client = utf8; set character_set_results = utf8; set character_set_connection = utf8; set collation_connection = utf8_general_ci 由于默认网页提交的查询是gb2312(表单页面meta里可以看到),而mysql默认将其当作utf8(可以查到此时的 character_set_client=utf8),所以必然乱码 。同理,mysql返回的结果是已经转换成 character_set_results编码的(与表的编码无关),同样默认是utf8,而网页页面把它当gb2312处理,所以必然有标题等由数据 库读出的字段是乱码而其他php部分文字不乱码的现象 。 解决(by 一剑飘雪): 复制代码 代码如下: $link = mysql_connect(localhost, root, root); mysql_query("SET NAMES utf8",$link); 这时我们在网页中看到的还是乱码但已不是????了,查看网页源文件,已完全正常 。用记事本打开php源文件,别存为utf8编码,再刷新网页,全部搞定了 。 但总不能每次连接时都发送一次SET NAMES utf8吧,如何彻底解决还没找到方法 。 这样安装mysql时缺省字符集选为utf8后又带来一个问题,我们在command.exe中进入mysql控制台后,查询结果又成了乱码,我们可以在查询前输入 复制代码 代码如下: mysql>set names gbk; 或 复制代码 代码如下: mysql>set names gb2312; 相当于告诉mysql客户端在使用gb2312字符集,结果就正确了,gb2312为GBK的子集. |