在编译php的时候,有这么几个和mysql关联的编译选项:
--with-mysql
--with-mysqli
--with-pdo-mysql
--enable-mysqlnd
那这几个选项到底有什么区别呢?
php官方文档上有这么一段话:
MySQL:This extension is deprecated as of HP 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。
翻译成中文大概意思是:
MySQL扩展:在5.5.0版本中起始废弃,7.0.0版本中已然移除(亦便是不支持了)
MySQLI扩展:是mysql扩展的加强版
MySQLnd:这是官方驱动,或叫做原生驱动
PDO:PHP Data Objects,是PHP应用中的一个数据库抽象层规范
在PHP扩展的方向上看,MYSQL和MYSQLi还是比较上层的扩展,依赖更底层的库去连接和拜访数据库。 MYSQLND 便是所说的底层的数据库驱动。
从应用的层面上看,咱们经过PHP 的MYSQL或MYSQLi扩展供给的API去操作数据库。
从底层来看,MYSQLND供给了底层和数据库交互的支持(能够简单理解为和MySQL server进行网络协议交互)。
而PDO,则供给了一个统一的API接口,使得你的PHP应用不去关心详细要连接的数据库服务器系统类型。亦便是说,倘若你运用PDO的API,能够在任何需要的时候无缝切换数据库服务器。例如MYSQL,SQLITE任何数据库都行。
即从大部分功能上看,PDO供给的API接口和MYSQLI供给的接口针对普通的增删改查效果是一致的。
最后再贴几个php的代码,来区分几个扩展的用法:
1) mysql连接
$conn = @ mysql_connect("localhost", "root", "") or die("数据库连接错误");
mysql_select_db("bbs", $conn);
mysql_query("set names utf8");
echo "数据库连接成功";
?>
2)mysqli连接
$conn = mysqli_connect(localhost, root, , bbs);
if(!$conn){
die("数据库连接错误" . mysqli_connect_error());
}
else{
echo"数据库连接成功";
} ?>
3)PDO连接
try{
$pdo=new pdo("mysql:host=localhost;dbname=bbs","root","");
}
catch(PDDException $e){
echo"数据库连接错误";
}
echo"数据库连接成功";
?>
- END -
出品 | 阿铭linux
私人微X:81677956 验证:公众号
提高自己,才是世界上最稳健的投资。
|