手册

目录

连接

收藏485

阅读2649

更新时间2025-08-06

我应该使用 MySQLi 还是 PDO?

如果您需要一个简短的答案,那就是“随您喜欢”。

MySQLi 和 PDO 都有各自的优点:

PDO 可以在 12 个不同的数据库系统上工作,而 MySQLi 仅能与 MySQL 数据库协同工作。

因此,如果您必须将项目切换到使用另一个数据库,PDO 会使该过程变得简单。您只需更改连接字符串和几个查询即可。而使用 MySQLi,您将需要重写整个代码 - 包括查询。

两者都是面向对象的,但 MySQLi 还提供了一个过程式 API。

两者都支持预处理语句。预处理语句可以防止 SQL 注入,对于 Web 应用程序的安全性非常重要。

MySQLi 和 PDO 语法中的 MySQL 示例

在本章和后续章节中,我们将展示使用 PHP 和 MySQL 协同工作的三种方式:

  • MySQLi(面向对象)
  • MySQLi(过程式)
  • PDO

MySQLi 安装

对于 Linux 和 Windows:在大多数情况下,当安装 php5 mysql 包时,MySQLi 扩展会自动安装。

有关安装详细信息,请访问:http://php.net/manual/en/mysqli.installation.php

PDO 安装

有关安装详细信息,请访问:http://php.net/manual/en/pdo.installation.php

打开到 MySQL 的连接

在我们可以访问 MySQL 数据库中的数据之前,我们需要能够连接到服务器:

实例(MySQLi 面向对象)

connect_error) {
  die("连接失败:" . $conn->connect_error);
}
echo "成功连接";
?>

关于上面面向对象的例子的注意事项:

$connect_error 在 PHP 5.2.9 和 5.3.0 之前是损坏的。如果您需要确保与 PHP 5.2.9 和 5.3.0 之前的版本兼容,请改用以下代码:

// 检查连接
if (mysqli_connect_error()) {
  die("数据库连接失败:" . mysqli_connect_error());
}

实例(MySQLi 过程式)


实例(PDO)

setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  echo "成功连接";
} catch(PDOException $e) {
  echo "连接失败:" . $e->getMessage();
}
?>

注意:在上面的 PDO 示例中,我们还指定了一个数据库(myDB)。PDO 需要连接到一个有效的数据库。如果没有指定数据库,则会抛出异常。

提示:PDO 的一个巨大优势是,它有一个异常类来处理可能在我们的数据库查询中发生的任何问题。如果在 try{ } 块中抛出异常,脚本将停止执行并直接流向第一个 catch(){ } 块。

关闭连接

当脚本结束时,连接将自动关闭。若要在之前关闭连接,请使用以下方式:

MySQLi 面向对象:

$conn->close();

MySQLi 过程式:

mysqli_close($conn);

PDO:

$conn = null;

科技资讯

更多

精选课程

更多
前端入门_HTML5
前端入门_HTML5

共29课时

61.7万人学习

CSS视频教程-玉女心经版
CSS视频教程-玉女心经版

共25课时

39.3万人学习

JavaScript极速入门_玉女心经系列
JavaScript极速入门_玉女心经系列

共43课时

70.9万人学习

独孤九贱(1)_HTML5视频教程
独孤九贱(1)_HTML5视频教程

共25课时

61.6万人学习

独孤九贱(2)_CSS视频教程
独孤九贱(2)_CSS视频教程

共22课时

23万人学习

独孤九贱(3)_JavaScript视频教程
独孤九贱(3)_JavaScript视频教程

共28课时

33.9万人学习

独孤九贱(4)_PHP视频教程
独孤九贱(4)_PHP视频教程

共89课时

125万人学习

关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号