文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

php读取mysql乱码的解决方法

2023-06-15 04:04

关注

这篇文章主要介绍php读取mysql乱码的解决方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

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

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

php读mysql乱码问题的总结

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

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

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])

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查询中的文本,使用什么编码。

连接数据库后,设置数据库间传输字符时所用的默认字符编码。

使用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; )

html页面使用的字符集。在meta标签中设置

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

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的框架:1、Laravel,Laravel是一款免费并且开源的PHP应用框架。2、Phalcon,Phalcon是运行速度最快的一个PHP框架。3、Symfony,Symfony是一款为Web项目准备的PHP框架。4、Yii,Yii是一款快速、安全和专业的PHP框架。5、CodeIgniter,CodeIgniter是一款非常敏捷的开源PHP框架。6、CakePHP,CakePHP是一款老牌的PHP框架。7.Kohana,Kohana是一款敏捷但是功能强大的PHP框架。

以上是“php读取mysql乱码的解决方法”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯