公司网站引导页,jsp网站开发四酷全书,微信 怎么上传 wordpress,广州制作软件本篇文章给大家介绍一下PHP连接MySQL数据库的三种方式(mysql、mysqli、pdo)#xff0c;结合实例形式分析了PHP基于mysql、mysqli、pdo三种方式连接MySQL数据库的相关操作技巧与注意事项。有一定的参考价值#xff0c;有需要的朋友可以参考一下#xff0c;希望对大家有所帮助…本篇文章给大家介绍一下PHP连接MySQL数据库的三种方式(mysql、mysqli、pdo)结合实例形式分析了PHP基于mysql、mysqli、pdo三种方式连接MySQL数据库的相关操作技巧与注意事项。有一定的参考价值有需要的朋友可以参考一下希望对大家有所帮助。PHP与MySQL的连接有三种API接口分别是PHP的MySQL扩展 、PHP的mysqli扩展 、PHP数据对象(PDO)下面针对以上三种连接方式做下总结以备在不同场景下选出最优方案。PHP的MySQL扩展是设计开发允许php应用与MySQL数据库交互的早期扩展。MySQL扩展提供了一个面向过程的接口并且是针对MySQL4.1.3或者更早版本设计的。因此这个扩展虽然可以与MySQL4.1.3或更新的数据库服务端进行交互但并不支持后期MySQL服务端提供的一些特性。由于太古老又不安全所以已被后来的mysqli完全取代PHP的mysqli扩展我们有时称之为MySQL增强扩展可以用于使用 MySQL4.1.3或更新版本中新的高级特性。其特点为面向对象接口 、prepared语句支持、多语句执行支持、事务支持 、增强的调试能力、嵌入式服务支持 、预处理方式完全解决了sql注入的问题。不过其也有缺点就是只支持mysql数据库。如果你要是不操作其他的数据库这无疑是最好的选择。PDO是PHP Data Objects的缩写是PHP应用中的一个数据库抽象层规范。PDO提供了一个统一的API接口可以使得你的PHP应用不去关心具体要连接的数据库服务器系统类型也就是说如果你使用PDO的API可以在任何需要的时候无缝切换数据库服务器比如从Oracle 到MySQL仅仅需要修改很少的PHP代码。其功能类似于JDBC、ODBC、DBI之类接口。同样其也解决了sql注入问题有很好的安全性。不过他也有缺点某些多语句执行查询不支持(不过该情况很少)。官文对于三者之间也做了列表性的比较PHP的mysqli扩展PDOPHP的mysql扩展引入的PHP版本5.05.03.0之前PHP5.x是否包含是是是MySQL开发状态活跃在PHP5.3中活跃仅维护在MySQL新项目中的建议使用程度建议 - 首选建议不建议API的字符集支持是是否服务端prepare语句的支持情况是是否客户端prepare语句的支持情况否是否存储过程支持情况是是否多语句执行支持情况是大多数否是否支持所有MySQL4.1以上功能是大多数否从官方给出的这份结果上来看优先推荐msqli其次是PDO 。而“民间”给出的结果很多是倾向于使用PDO因为其不担有跨库的优点更有读写速度快的特点。1、PHP与Mysql扩展(本扩展自 PHP 5.5.0 起已废弃并在将来会被移除)PHP原生的方式去连接数据库是面向过程的$mysql\_conf array(host 127.0.0.1:3306,db test,db\_user root,db\_pwd root,);$mysql\_conn mysql\_connect($mysql\_conf\[host\], $mysql\_conf\[db\_user\], $mysql\_conf\[db\_pwd\]);if (!$mysql\_conn) {die(could not connect to the database:\\n . mysql\_error());//诊断连接错误}mysql\_query(set names utf8);//编码转化$select\_db mysql\_select\_db($mysql\_conf\[db\]);if (!$select\_db) {die(could not connect to the db:\\n . mysql\_error());}$sql select \* from user;;$res mysql\_query($sql);if (!$res) {die(could get the res:\\n . mysql\_error());}while ($row mysql\_fetch\_assoc($res)) {print\_r($row);}mysql\_close($mysql\_conn);?2、PHP与Mysqli扩展,面向过程、对象$mysql\_conf array(host 127.0.0.1:3306,db test,db\_user root,db\_pwd joshua317,);$mysqli new mysqli($mysql\_conf\[host\], $mysql\_conf\[db\_user\], $mysql\_conf\[db\_pwd\]);if ($mysqli-connect\_errno) {die(could not connect to the database:\\n . $mysqli-connect\_error);//诊断连接错误}$mysqli-query(set names utf8;);//编码转化$select\_db $mysqli-select\_db($mysql\_conf\[db\]);if (!$select\_db) {die(could not connect to the db:\\n . $mysqli-error);}$sql select uid from user where name joshua;;$res $mysqli-query($sql);if (!$res) {die(sql error:\\n . $mysqli-error);}while ($row $res-fetch\_assoc()) {var\_dump($row);}$res-free();$mysqli-close();?3、PHP与PDO扩展,面向过程、对象$mysql\_conf array(host 127.0.0.1:3306,db test,db\_user root,db\_pwd joshua317,);$pdo new PDO(mysql:host . $mysql\_conf\[host\] . ;dbname . $mysql\_conf\[db\], $mysql\_conf\[db\_user\], $mysql\_conf\[db\_pwd\]);//创建一个pdo对象$pdo-exec(set names utf8);$sql select \* from user where name ?;$stmt $pdo-prepare($sql);$stmt-bindValue(1, joshua, PDO::PARAM\_STR);$rs $stmt-execute();if ($rs) {// PDO::FETCH\_ASSOC 关联数组形式// PDO::FETCH\_NUM 数字索引数组形式while ($row $stmt-fetch(PDO::FETCH\_ASSOC)) {var\_dump($row);}}$pdo null;//关闭连接?以上内容希望帮助到大家很多PHPer在进阶的时候总会遇到一些问题和瓶颈业务代码写多了没有方向感不知道该从那里入手去提升对此我整理了一些资料包括但不限于分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6laravelYII2RedisSwoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家需要的可以点击链接获取进阶PHP月薪30k架构师成长路线【视频、面试文档免费获取】