php显示数据库中文 php显示数据库内容

高手求救,php调用mysql数据库不能显示中文呈乱码?以前php显示数据库中文的国外主机用的Mysql是4.x系列的php显示数据库中文 , 感觉还比较好,都无论GBK和UTF-8都没有乱码,没想到新的主机的Mysql是5.0版本的,导入数据后,用Php读出来全是问号,乱码一片,记得我以前也曾经有过一次切换出现乱码的经验,原因肯定是Mysql版本之间的差异问题 。
只好查资料,发现了一个解决方法 , 就是在mysql_connect后面加一句SET
NAMES
UTF8 , 即可使得UTF8的数据库消除乱码,对于GBK的数据库则使用SET
NAMES
GBK,代码如下:
$mysql_mylink
=
mysql_connect($mysql_host,
$mysql_user,
$mysql_pass);
mysql_query("SET
NAMES
'GBK'");
用PHP从数据库中取出的中文是乱码,怎么处理能使中文正常显示?数据库采用UTF8编码,而页面申明编码是GB2312,这是最常见的产生乱码的原因 。这时候在PHP脚本里面直接SELECT数据出来的就是乱码,需要在查询前先使用:mysql_query("SET NAMES GBK");或mysql_query("SET NAMES GB2312");来设定MYSQL连接编码 , 保证页面申明编码与这里设定的连接编码一致(GBK是GB2312的扩展) 。如果页面是UTF-8编码的话,可以用:mysql_query("SET NAMES UTF8"); 注意是UTF8而不是一般用的UTF-8 。假如页面申明的编码与数据库内部编码一致可以不设定连接编码 。
事实上MYSQL配置文件my.ini中定义了2个默认编码,分别是[client]里的default-character-set和[mysqld]里的default-character-set来分别设定默认时候客户端连接和数据库内部所采用的编码 。上面指定的编码其实是MYSQL客户端连接服务器时候的命令行参数character_set_client , 来告诉MYSQL服务器接受到的客户端数据是什么编码的,而不是采用默认编码 。
转自:
php显示中文乱码 , phpmyadmin里的MySQL数据库中文乱码,如何解决?将浏览器中的编码改成utf-8,数据库中也是 。在php页面首行加上header("Content-type:
text/html;
charset=utf-8");,必须首行 , 前面不能有输出 。
还有,在查询数据库时加上:mysql_query(set
names
utf-8);
PHP在显示数据库中的中文数据时显示乱码其实 , 只要注意文件编写的时候编码、数据库的编码一般就不会有这个问题的,但是 , 比如你用DW(dwcs4貌似没有这个现象)打开文件 , 它会以默认的编码读取,一旦你保存了,那就完了,用EditPlus打开之后,右下角有编码提示,如果发现不对,另存为 , 覆盖一下 , 就可以了
我的php不能显示mysql数据库中的中文我来给你做一个综合解释吧 。
在正常情况下 。
PHP脚本HTML已经浏览器然后就是数据库 。
都有自己的字符集 。何谓字符集 。我想你如果是一个真正想热衷于学PHP
那么你应该花一定的时间去了解一下字符集的问题 。
因为无论你以后做什么项目开发什么网站都是要牵涉到字符集 。
就好比我做第一个项目 。因为字符集搞的死去活来 。
好进入正题 。怎么解决问题呢?
1.PHP的字符集 。一般PHP网页的是嵌套在html页面以内 。那么如果在没有冲突的情况下可以使用
header方面设置 。比如?phpheader ...?
2.HTML的字符集,一般是网页的优先字符集,这个问题是牵涉到你的网站是什么定位,比如:你的网站仅仅适合国内的客户 。那么用gbk或者gb2312.如果想老外也开凑凑热闹的话,就用utf-8.至于怎么设置这个字符集,你可以在meta这个标记中看到 。
【php显示数据库中文 php显示数据库内容】

推荐阅读