总结mysql php乱码问题-PHP问题

资源魔 17 0

处理mysql php乱码成绩:一、建设数据库表时指定命据库表的字符集;二、设置mysql的字符集;三、衔接数据库后,设置数据库间传输字符时所用的默许字符编码;四、设置html页面应用的字符集。

php读mysql时,有如下几个中央触及到了字符集。

1. 建设数据库表时指定命据库表的字符集。例如

 create table tablename 
 ( 
 id int not null auto_increment, 
 title varchar(20) not null,  
 primary key ('id') 
 )DEFAULT CHARSET =UTF8;

假如正在创立表时不指定表的字符集,则应用表所属的数据库的默许字符集。该字符集由character_set_database指定。
查看数据库表所应用的字符集的办法是:

show create table mytable;

(PS:建设数据库/表以及进行数据库操作时只管即便显式指出应用的字符集,而没有是依赖于MySQL的默许设置,不然MySQL晋级时可能带来很年夜困扰[1])

2. mysql的字符集
mysql中有三个首要的变量,character_set_client,character_set_results,character_set_connection。
经过设置character_set_client,通知Mysql,PHP存进数据库的是甚么编码形式。
经过设置character_set_results,通知Mysql,PHP需求取甚么样编码的数据。
经过设置character_set_connection,通知Mysql,PHP查问中的文本,应用甚么编码。

3. 衔接数据库后,设置数据库间传输字符时所用的默许字符编码。
应用mysqli::set_charset()或mysqli::query('set names utf8'),进行设置。
只管即便应用mysqli::set_charset(mysqli:set_charset)而没有是”SET NAMES”(参考这篇文章)

$db = new mysqli('localhost','user','passwd','database_name');$db->set_charset('utf8');

留意是utf8,没有是utf-8
(这里有个成绩就是,数据库以及php都曾经对立了编码,然而假如不挪用mysqli::set_charset()函数时,读出数据时依然会呈现乱码。这是为何?)
(另,set names utf8相称于上面三句
SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = utf8;


4. html页面应用的字符集。正在meta标签中设置

<meta http-equiv="content-type" content="text/html; charset=utf-8">

5. php文本文件所应用的字符集。
正在linux下能够用vim关上文件,输出
:set encoding
查看文件应用的字符集

要保障没有乱码,需求保障文件本身的编码,HTML里指定的编码,PHP通知Mysql的编码(包罗character_set_client以及character_set_results)对立。同时应用mysqli:set_charset()函数或”SET NAMES”。

针对“3”前面的成绩,写了几个例子,测试链接数据库后,设置以及没有设置字符集时的后果。测试环境Ubuntu 12.04,MySQL 5.5,php 5.5.7。
后果以下:
(1) 数据库表字符集是utf8,没有应用set names utf8
能失常拔出、读出中文,然而正在mysql中显示乱码

(2) 数据库表字符集是utf8,应用set names utf8
能失常拔出、读出中文,mysql中显示正确

(3) 数据库表字符集没有是utf8,应用set names utf8
mysql中显示,读出都是问号。

不少相干常识,请拜访PHP中文网!

以上就是总结mysql php乱码成绩的具体内容,更多请存眷资源魔其它相干文章!

标签: php mysql php教程 php故障解决 php使用问题

抱歉,评论功能暂时关闭!