数据库php显示数据乱码 php数据库中文乱码怎么解决

用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 。假如页面申明的编码与数据库内部编码一致可以不设定连接编码 。
【数据库php显示数据乱码 php数据库中文乱码怎么解决】事实上MYSQL配置文件my.ini中定义了2个默认编码,分别是[client]里的default-character-set和[mysqld]里的default-character-set来分别设定默认时候客户端连接和数据库内部所采用的编码 。上面指定的编码其实是MYSQL客户端连接服务器时候的命令行参数character_set_client,来告诉MYSQL服务器接受到的客户端数据是什么编码的,而不是采用默认编码 。
转自:
PHP在显示数据库中的中文数据时显示乱码其实 , 只要注意文件编写的时候编码、数据库的编码一般就不会有这个问题的,但是,比如你用DW(dwcs4貌似没有这个现象)打开文件,它会以默认的编码读取 , 一旦你保存了,那就完了,用EditPlus打开之后,右下角有编码提示,如果发现不对,另存为 , 覆盖一下,就可以了
PHP读取Access数据库 出乱码access的中文版默认是GBK格式的,是无法改变字符类型的,所以用php读取的时候会乱码 。
解决方法是:使用iconv转换
一、使用 iconv函数制作一个转码的自定义从GBK转到UTF-8的函数,如以下代码:
function enc($c){return iconv('gbk','utf-8',$c);}
二、为了写入数据库的编码是符合数据库需要的 , 所以我们还要制作一个从UTF-8转向GBK的函数:
function dec($c){return iconv('utf-8','gb2312',$c);}
制作好了转码函数,接下就是正常使用了 。在从数据库里面调数据显示在页面的时候使用enc()函数,从页面提交数据到数据库时使用dec()函数 , 这样就可以很好的解决PHP使用UTF-8编码,ACCESS使用系统默认编码的问题了 。
在PHP页面显示数据库内容时 页面中文部分出现乱码一般来说,乱码问题其实也就是编码不一致导致的 。因此,要解决PHP中文乱码问题,解决步骤有如下几步:
1.页面声明的编码 与 数据库内部编码 一致
比如: 你的网页里设置 charset = gb2312,然而,你的数据库使用utf-8 , 那么 , 如果不进行iconv转换的话 , 显示出来可能就有问题 。
2.页面文件的编码 与 页面声明的编码 一致
比如,你的网页文件为 test.php,该文件用 UTF-8B 格式保存,而如果你的网页里设置 charset = gb2312,那么可能显示也不正常 。
从你的问题描述来看,“PHP中非数据库导出的部分 其中文显示正常 ” , 据此可以确定页面文件编码与页面声明编码一致,那么,问题原因就在于:
页面声明的编码 与 数据库内部编码 不一致造成的 。
你可以查看下,你的 数据库编码格式 与 网页定义的编码 。
php 往数据库里插入 数据,插入和读取正常显示中文,但 数据库 里显示乱码怎么破?可能是代码格式不一致,你把编码格式改成“utf8” , 数据库-操作-排序规则改成统一的格式试试看
数据库php显示数据乱码的介绍就聊到这里吧,感谢你花时间阅读本站内容 , 更多关于php数据库中文乱码怎么解决、数据库php显示数据乱码的信息别忘了在本站进行查找喔 。

    推荐阅读