PHP读MYSQL中文乱码的快速解决方法打算切换某个网站的主机php与数据库乱码,没想到遇到Php和Mysql中文乱码的问题 。
以前的国外主机用的Mysql是4.x系列的php与数据库乱码,感觉还比较好,都无论GBK和UTF-8都没有乱码,没想到新的主机的Mysql是5.0版本的 , 导入数据后,用Php读出来全是问号,乱码一片,记得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读MYSQL中文乱码的快速解决方法的全部内容了,希望对大家有所帮助 , 多多支持脚本之家~
用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读取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数据库中文乱码怎么解决】php与数据库乱码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于php数据库中文乱码怎么解决、php与数据库乱码的信息别忘了在本站进行查找喔 。
推荐阅读
- Q版单机游戏苹果,好玩的q版单机游戏
- gis控制点坐标转成表格,gis坐标设置
- 阿里云国际服务器费用,阿里云服务器怎么收费标准
- mysql语句怎么去重复 mysql去掉重复行命令
- mysql多表还不如单表,mysql多表连接的方式
- 什么牌子手机像素高,什么牌子手机像素高清
- 微信直播如何,微信直播如何举报主播
- python十大常用函数的简单介绍
- zblog页面调用分类,zblog使用