当前位置: 首页 > 工具软件 > mysqlnd > 使用案例 >

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

方和宜
2023-12-01

名词解释:
最开始的初学者,往往搞不清mysqli,mysqlnd,pdo到底是什么,下面先直接贴出最直观的名字吧。

MYSQL:This extension is deprecated as of PHP 5.5.0, and has been
removed as of PHP 7.0.0. MYSQLI: MySQL Improved Extension MySQLND:
MySQL Native Drive PDO:The PHP Data Objects。extension defines a
lightweight, consistent interface for accessing databases in PHP。

以上摘自 PHP官方手册: http://php.net/manual/en/book.mysqli.php

用中文说:

  • MYSQL 也叫 Original MySQL,PHP4版本的MYSQL扩展,从PHP5起已经被废弃,并别从PHP7开始已经被移除。
  • MYSQLI 叫做 “MySQL增强扩展”。
  • MYSQLND MYSQL NATIVE DIRVER 叫做MYSQL “官方驱动”或者更加直接点的叫做“原生驱动”
  • PDO PHP Data Objects PHP数据对象,是PHP应用中的一个数据库抽象层规范。

针对本篇文章

再补充几个名词解释:

  1. 什么是API?

一个应用程序接口(Application Programming Interface的缩写),定义了类,方法,函数,变量等等一切
你的应用程序中为了完成特定任务而需要调用的内容。在PHP应用程序需要和数据库进行交互的时候所需要的API
通常是通过PHP扩展暴露出来(给终端PHP程序员调用)。

上文所说的MYSQL 和MYSQLI扩展就提供了这样的API。

  1. 什么是驱动?

驱动是一段设计用来于一种特定类型的数据库服务器进行交互的软件代码。驱动可能会调用一些库,比如MySQL客户端库或者MySQL
Native驱动库。 这些库实现了用于和MySQL数据库服务器进行交互的底层协议。

在PHP拓展的角度上看,MYSQL和MYSQLi还是比较上层的拓展,依赖更底层的库去连接和访问数据库。
上文所说的MYSQLND 就是所说的底层的数据库驱动。当然,还有一个驱动叫做libmysqlclient。至于如何选择使用这两种驱动的哪一种,请看这里选择哪一种底层数据库驱动

总的来说:
从应用的层面上看,我们通过PHP 的MYSQL或者MYSQLi扩展提供的API去操作数据库。

从底层来看,MYSQLND提供了底层和数据库交互的支持(可以简单理解为和MySQL server进行网络协议交互)。

而PDO,则提供了一个统一的API接口,使得你的PHP应用不去关心具体要连接的数据库服务器系统类型。也就是说,如果你使用PDO的API,可以在任何需要的时候无缝切换数据库服务器。比如MYSQL,SQLITE任何数据库都行。

即从大部分功能上看,PDO提供的API接口和MYSQLI提供的接口对于普通的增删改查效果是一致的。

最后贴下代码:

MYSQL连接:

<?php

$conn = @ mysql_connect("localhost", "root", "") or die("数据库连接错误");

mysql_select_db("bbs", $conn);

mysql_query("set names 'utf8'");

echo "数据库连接成功";

?>

MYSQLI连接:

<?php

$conn = mysqli_connect('localhost', 'root', '', 'bbs');

if (!$conn) {
	die("数据库连接错误" . mysqli_connect_error());
} else {
	echo "数据库连接成功";
}

PDO连接:

<?php

try{
	$pdo = new pdo("mysql:host=localhost;dbname=bbs","root","");
} catch(PDDException $e) {
	echo "数据库连接错误";
}

echo "数据库连接成功";

?>

想更多去了解他们的区别和联系,可以手动去编译一下PHP的源代码。注意参数

--enable-pdo 
--with-pdo-mysql
--enable-mysqlnd 
--with-mysqli
--with-mysql//php7的已经不再支持,此参数configure 的时候会报ERROR

既然PHP有mysql、mysqli、pdo_mysql这么多驱动,那么我们如何选择呢?

  • mysqli是mysql增强版扩展,mysqli支持mysql4.1.3+的高级特性,相对于mysql扩展的提升主要有:面向对象接口、prepared语句支持、多语句执行支持、事务支持、增强的调试能力、嵌入式服务支持等。

那现在mysql就排除了,接下来是mysqli和pdo_mysql之间的选择。

  • mysqli是专门针对mysql设计的,而pdo支持多种数据库(当然如果要使用pdo并且连接mysql类型数据库就需要安装pdo_mysql,连接其他数据库就要安装对应pdo的实现,比如pdo_sqlsrv等等)。
  • mysqli和pdo_mysql都很优秀,所以还是要根据自己的业务选择,如果铁定就用mysql了,不可能和其他类型数据库交互,那可以选择使用mysqli,如果想灵活一些,就可以选择用pdo_mysql。

我自己是经常用laravel这个PHP框架的,laravel默认不支持mysqli(也有很多mysqli的操作库可以加上去强行支持mysqli),所以还是尽量使用pdo_mysql。

参考文章:https://blog.csdn.net/u012628581/article/details/86701815

 类似资料: