php读mysql乱码怎么办

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

php读mysql乱码怎么办

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

php读mysql乱码问题的总结

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

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

立即学习“PHP免费学习笔记(深入)”;

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');

登录后复制

注意是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标签中设置


登录后复制

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视频教程》

以上就是php读mysql乱码怎么办的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2514909.html

(0)
上一篇 2025年3月5日 15:37:03
下一篇 2025年3月3日 17:36:29

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • php怎么删除开头字符串

    php删除开头字符串的方法:1、通过“substr($str, strlen($prefix));”方式删除;2、通过“preg_replace(‘/^’ . preg_quote($prefix, ‘/…

    2025年3月5日
    200
  • php html怎么转text

    php html转text的方法:首先创建一个PHP示例文件;然后通过“function html2text($str){…}”方法对html中的标记进行替换即可。 本文操作环境:Windows7系统、PHP7.1版,DELL …

    2025年3月5日
    200
  • PHP如何添加变量呢?(附源码)

    什么是php变量,又如何去设置php的变量呢?本章就让“小白“带你初入了解php,如何一点点成为php大神,一起聊聊吧 什么是变量? 变量是用于存储在信息的“容器”; 代码如下: 立即学习“PHP免费学习笔记(深入)”; 登录后复制 就像数…

    2025年3月5日
    200
  • php数组元素排序的方法是什么

    PHP中可使用array_multisort()、asort()、arsort()、krsort()、ksort()、natcasesort()、natsort()、rsort()、shuffle()、sort()等函数对数组元素进行排序。…

    2025年3月5日
    200
  • php关联数组怎么增加元素

    php关联数组增加元素的方法:1、利用array_merge()函数,合并两个关联数组来增加元素,语法“array_merge(关联数组1,关联数组2)”;2、利用“+”运算符,合并两个关联数组来增加元素,语法“关联数组1+关联数组2”。 …

    2025年3月5日
    200
  • php怎么将二维数组转为多个一维数组

    php将二维数组转多个一维数组的方法:1、使用array_reduce()函数来转换;2、使用array_walk_recursive()函数来转换;3、使用array_map()函数来转换。 本教程操作环境:windows7系统、PHP7…

    2025年3月5日
    200
  • php怎么手动安装插件

    php手动安装插件的方法:1、安装相关的库,如zlib、curl、xml等,然后设置“–with-xxx”;2、通过“phpize”指明安装路径,然后通过“make install”命令安装即可。 本文操作环境:linux5.9…

    2025年3月5日
    100
  • php怎么拦截错误信息

    php拦截错误信息的方法:1、在错误语句之前加上@符号;2、将“display_errors=on”改为off;3、使用函数“display_errors”关闭错误显示。 本文操作环境:Windows7系统、PHP7.1版,DELL G3电…

    2025年3月5日
    200
  • php怎么增加验证码

    php增加验证码的实现方法:首先新建一个captcha.php;然后创建静态页的代码;最后创建一个判断的“form.php”代码即可。 本文操作环境:Windows7系统、PHP7.1版,DELL G3电脑 php怎么增加验证码? 现在来说…

    2025年3月5日
    200
  • xp php怎么一键安装

    xp php一键安装的方法:首先下载phpStudy;然后双击phpStudy.exe,打开软件进入程序主页面;接着设置站点和域名;最后复制程序到网站根目录,并在程序界面点击启动即可。 本文操作环境:Windows xp系统、phpstud…

    2025年3月5日 编程技术
    200

发表回复

登录后才能评论