好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

php读mysql乱码怎么办

php读mysql乱码的解决办法:1、建立数据库表时指定数据库表的字符集;2、设置mysql的字符集;3、设置数据库间传输字符时所用的默认字符编码;4、设置html页面使用的字符集;5、设置php文本文件所使用的字符集。

本文操作环境:Windows7系统、PHP7.1版,DELL G3电脑

php读mysql乱码问题的总结

php读mysql时,有以下几个地方涉及到了字符集。

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

1 create table tablename 
2 ( 
3 id int not null auto_increment, 
4 title varchar(20) not null,  
5 primary key ('id') 
6 )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');

(这里有个问题就是,数据库和php都已经统一了编码,但是如果没有调用mysqli::set_charset()函数时,读出数据时仍然会出现乱码。这是为什么?)

(另,set names utf8相当于下面三句
SET character_set_client = utf8;
SET character_set_results = utf8; 
SET character_set_connection = utf8; 
)

mysql中显示,读出都是问号。

推荐学习:《PHP视频教程》

以上就是php读mysql乱码怎么办的详细内容!

查看更多关于php读mysql乱码怎么办的详细内容...

  阅读:49次