最新消息: 新版网站上线了!!!

php和mysql 转码问题

php编辑器使用UTF-8,html中charset也是UTF-8,mysql建立数据库和建表都使用utf8。数据存入数据库后,读写都正常。但是使用navicat查看表数据时却显示乱码。

在建立数据库连接后,增加代码mysql_query('set names utf8') ,问题解决。

查看mysql_query的作用。网上论坛有文解释如下,我的理解大概这样:客户端在提交到数据库的过程中需要一个字符集转换的过程,mysql默认为拉丁文。所有需要设定所提交的数据编码为utf8,才可以正常显示。

在mysql数据库中有3个变量:
character_set_client
character_set_connection
character_set_results
你可以分别理解为:客户端 连接器 返回值


客户端 :通常有cmd下的命令行,或者浏览器
连接器 :这个比较抽象,我们看不到,应该是在mysql数据库中的
返回值 : 就是以什么样的字符编码来给客户端

我们一般在cmd下set names gbk 或者php文件中 mysql_query('set names utf8'),其实就是相当于同时设置上面所说的3个变量的值为 gbk 或者 utf8 ,也就是客户端、连接器、返回值都为一样的字符编码,如果你足够耐心也可以再mysql命令行下分别设置这3个变量的值,比如:

set character_set_client =gbk;
set character_set_connection = gbk;
set character_set_results = gbk;

按照你说的 数据库已经设置了utf-8 ,php文件也设置了utf-8 ,而且在添加了 set names utf8 就不乱吗了,你应该是用浏览器查看的吧?这么说你的浏览器应该是urf8字符集了,那么问题应该就是出在 连接器 这个环节上。字符集设置有个限制,那就是字符集编码的大小,应该是这个规律: 客户端 <= 连接器 <= 服务端 

那么我在说下连接器的作用,连接器就是接受客户端传来的数据,先接受保存起来,在转换成服务端所需的字符编码。比如客户端是GBK ,连接器也是GBK,服务端是UTF8,那么 连接器就会把客户端传来的GBK数据先存储起来,转换成服务器的UTF8后传给服务器。

那么回到字符集设置规律上,GBK存储汉字需要2个字节,UFT8存储汉字需要3个字节 ,如果你的客户端是UTF8,而连接器是GBK,那么就会在存储上出现问题,所以存入数据库后就会乱码。

 

告诉mysql服务器(字符集转换器)把后面要发送的sql语句使用的字符集当作指定的字符集来解析,并且返回的结果数据的字符集也是指定的字符集。作用就是保证客户端(sql语句)和服务器端使用的编码一致,不至于出现乱码或数据丢失。

转载请注明:谷谷点程序 » php和mysql 转码问题