高手求救,php调用mysql数据库不能显示中文呈乱码?以前的国外主机用的Mysql是4.x系列的,感觉还比较好,都无论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);
【php数据库查询中文是码 php数据库查询语句】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读取mysql中文乱码的情况把你数据库中查询出来的中文都进行下编码转化:
iconv('latin1','你想要的编码格式','需要转化的中文(注意只能为字符串,不能直接使用数组)');
php连接数据库插入数据后 , mysql中查询汉字字符乱码解决乱码有几种方式:
在读取数据库的时候设置连接编码:mysql_query("set
names
utf8");
在读取数据库的php文件的头部加:header("Content-type:text/html;charset=utf-8");
php文件不是utf8格式的编码,需要转化 。用notpad文本编辑器打开php文件,点击菜单中的“格式”,查看是否是“以utf8
无bom格式编码” , 不是的话请转成此格式 。
html格式的在头部加上:meta
http-equiv="Content-Type"
content="text/html;
charset=utf-8"
/
你看看你的是哪一种情况,都对比做的一下 , 还不行在问我 。
php数据库中文乱码是怎么造成的?确保三码合一就可以了..
第一个是数据库的字符集
第二个就是存进去的时候字符集
第三个就是显示的时候的字符集
这三个都有可能造成乱码;
第一个 举例是:如果你插入的时候用的是GB2312 ,但你表中的default charset是utf8 那么,就有可能乱码了.
第二种情况就是你插入正确但你查询的时候以UTF8查询出来,但你在HTML页面里设置编码如果非UTF8那么也有可能造成乱码.
关于php数据库查询中文是码和php数据库查询语句的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。
推荐阅读
- 少年歌行下载,少年歌行下载百度网盘
- 拍摄景点有什么好处,拍摄景点有什么好处吗
- 新网络怎么插路由器,新装的网怎么设置路由器
- mysql怎么创建两个数据库 mysql创建多个数据库
- 段子手都用什么拍摄,拍段子是用手机拍的还是摄像机
- 明星胖什么胖视频大全,明星胖胖的
- 提示电脑硬盘异常怎么处理,电脑硬件硬盘出现异常
- c语言中的位数用什么函数 c语言中的位与
- html5如何开发手机端,html手机开发工具