简要谈谈php中mysql,mysqli,mysqlnd,pdo到底是什么.

MYSQL 也叫 Original MySQL,PHP4版本的MYSQL扩展,从PHP5起已经被废弃,并别从PHP7开始已经被移除。文章源自靠谱运维-https://www.ixdba.net/archives/1132

MYSQLI 叫做 “MySQL增强扩展”。文章源自靠谱运维-https://www.ixdba.net/archives/1132

MYSQLND MYSQL NATIVE DIRVER 叫做MYSQL “官方驱动”或者更加直接点的叫做“原生驱动”文章源自靠谱运维-https://www.ixdba.net/archives/1132

PDO PHP Data Objects PHP数据对象,是PHP应用中的一个数据库抽象层规范。文章源自靠谱运维-https://www.ixdba.net/archives/1132

针对本篇文章文章源自靠谱运维-https://www.ixdba.net/archives/1132

再补充几个名词解释:
1 什么是API?文章源自靠谱运维-https://www.ixdba.net/archives/1132

一个应用程序接口(Application Programming Interface的缩写),定义了类,方法,函数,变量等等一切 你的应用程序中为了完成特定任务而需要调用的内容。在PHP应用程序需要和数据库进行交互的时候所需要的API 通常是通过PHP扩展暴露出来(给终端PHP程序员调用)。文章源自靠谱运维-https://www.ixdba.net/archives/1132

上文所说的MYSQL 和MYSQLI扩展就提供了这样的API。文章源自靠谱运维-https://www.ixdba.net/archives/1132

2什么是驱动?文章源自靠谱运维-https://www.ixdba.net/archives/1132

驱动是一段设计用来于一种特定类型的数据库服务器进行交互的软件代码。驱动可能会调用一些库,比如MySQL客户端库或者MySQL Native驱动库。 这些库实现了用于和MySQL数据库服务器进行交互的底层协议。文章源自靠谱运维-https://www.ixdba.net/archives/1132

在PHP拓展的角度上看,MYSQL和MYSQLi还是比较上层的拓展,依赖更底层的库去连接和访问数据库。
上文所说的MYSQLND 就是所说的底层的数据库驱动。当然,还有一个驱动叫做libmysqlclient。至于如何选择使用这两种驱动的哪一种,请看这里选择哪一种底层数据库驱动。文章源自靠谱运维-https://www.ixdba.net/archives/1132

总的来说:
从应用的层面上看,我们通过PHP 的MYSQL或者MYSQLi扩展提供的API去操作数据库。文章源自靠谱运维-https://www.ixdba.net/archives/1132

从底层来看,MYSQLND提供了底层和数据库交互的支持(可以简单理解为和MySQL server进行网络协议交互)。文章源自靠谱运维-https://www.ixdba.net/archives/1132

而PDO,则提供了一个统一的API接口,使得你的PHP应用不去关心具体要连接的数据库服务器系统类型。也就是说,如果你使用PDO的API,可以在任何需要的时候无缝切换数据库服务器。比如MYSQL,SQLITE任何数据库都行。文章源自靠谱运维-https://www.ixdba.net/archives/1132

即从大部分功能上看,PDO提供的API接口和MYSQLI提供的接口对于普通的增删改查效果是一致的。文章源自靠谱运维-https://www.ixdba.net/archives/1132

最后贴下代码:文章源自靠谱运维-https://www.ixdba.net/archives/1132

MYSQL连接:文章源自靠谱运维-https://www.ixdba.net/archives/1132

<?php文章源自靠谱运维-https://www.ixdba.net/archives/1132

$conn = @ mysql_connect("localhost", "root", "") or die("数据库连接错误");文章源自靠谱运维-https://www.ixdba.net/archives/1132

mysql_select_db("bbs", $conn);文章源自靠谱运维-https://www.ixdba.net/archives/1132

mysql_query("set names 'utf8'");文章源自靠谱运维-https://www.ixdba.net/archives/1132

echo "数据库连接成功";文章源自靠谱运维-https://www.ixdba.net/archives/1132

?>文章源自靠谱运维-https://www.ixdba.net/archives/1132

MYSQLI连接:文章源自靠谱运维-https://www.ixdba.net/archives/1132

<?php文章源自靠谱运维-https://www.ixdba.net/archives/1132

$conn = mysqli_connect('localhost', 'root', '', 'bbs');文章源自靠谱运维-https://www.ixdba.net/archives/1132

if(!$conn){文章源自靠谱运维-https://www.ixdba.net/archives/1132

die("数据库连接错误" . mysqli_connect_error());文章源自靠谱运维-https://www.ixdba.net/archives/1132

}else{文章源自靠谱运维-https://www.ixdba.net/archives/1132

echo"数据库连接成功";文章源自靠谱运维-https://www.ixdba.net/archives/1132

}文章源自靠谱运维-https://www.ixdba.net/archives/1132

?>文章源自靠谱运维-https://www.ixdba.net/archives/1132

PDO连接:文章源自靠谱运维-https://www.ixdba.net/archives/1132

<?php文章源自靠谱运维-https://www.ixdba.net/archives/1132

try{文章源自靠谱运维-https://www.ixdba.net/archives/1132

$pdo=new pdo("mysql:host=localhost;dbname=bbs","root","");文章源自靠谱运维-https://www.ixdba.net/archives/1132

}catch(PDDException $e){文章源自靠谱运维-https://www.ixdba.net/archives/1132

echo"数据库连接错误";文章源自靠谱运维-https://www.ixdba.net/archives/1132

}文章源自靠谱运维-https://www.ixdba.net/archives/1132

echo"数据库连接成功";文章源自靠谱运维-https://www.ixdba.net/archives/1132

?>文章源自靠谱运维-https://www.ixdba.net/archives/1132

想更多去了解他们的区别和联系,可以手动去编译一下PHP的源代码。注意参数文章源自靠谱运维-https://www.ixdba.net/archives/1132

--enable-pdo
--with-pdo-mysql
--enable-mysqlnd
--with-mysqli
--with-mysql//php7的已经不再支持,此参数configure 的时候会报ERROR文章源自靠谱运维-https://www.ixdba.net/archives/1132

文章源自靠谱运维-https://www.ixdba.net/archives/1132
  • 本文由 发表于 2018年3月15日12:00:11
  • 转载请务必保留本文链接:https://www.ixdba.net/archives/1132
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: