跳转到主要内容
你行网

Main navigation

  • 首页
  • Drupal
  • 编程与开发
  • 数据库
  • 操作系统与应用
  • 服务器与运维
  • 社区
User account menu
  • 登录

面包屑

  1. 首页

PDO 和 MySQLi 连接数据库的区别

由 hrs, 16 三月, 2025

PDO 和 MySQLi 是 PHP 中用于连接和操作 MySQL 数据库的两种主要扩展。它们各有优缺点,适用于不同的场景。以下是它们的详细对比:

1. 基本概念
PDO(PHP Data Objects):

是一个数据库访问抽象层,支持多种数据库(如 MySQL、PostgreSQL、SQLite 等)。

提供一致的 API,可以在不同数据库之间切换,而无需重写大量代码。

MySQLi(MySQL Improved):

是 MySQL 的专用扩展,仅支持 MySQL 数据库。

提供了面向对象和面向过程两种编程接口。

2. 连接方式
PDO 连接示例


<?php
$host = 'localhost';
$dbname = 'blog_system';
$username = 'root';
$password = '020123';
try {
   $conn = new PDO("mysql:host=$host;dbname=$dbname", $username, $password);
   $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
   echo "PDO 连接成功!";
} catch (PDOException $e) {
   die("PDO 连接失败: " . $e->getMessage());
}
?>


MySQLi 连接示例


<?php
$host = 'localhost';
$username = 'root';
$password = '020123';
$dbname = 'blog_system';
$conn = new mysqli($host, $username, $password, $dbname);
if ($conn->connect_error) {
   die("MySQLi 连接失败: " . $conn->connect_error);
}
echo "MySQLi 连接成功!";
?>


3. 主要区别
特性    PDO    MySQLi
数据库支持    支持多种数据库(如 MySQL、PostgreSQL 等)    仅支持 MySQL
API 风格    仅面向对象    支持面向对象和面向过程
预处理语句    支持命名占位符(如 :name)    仅支持位置占位符(如 ?)
错误处理    支持异常处理(PDOException)    支持异常处理(需要手动启用)
性能    稍慢    稍快
功能丰富性    功能较少,但足够通用    功能更丰富(如异步查询、多语句执行等)
学习曲线    较简单    较复杂
4. 预处理语句
PDO 预处理语句


$sql = "SELECT * FROM users WHERE id = :id";
$stmt = $conn->prepare($sql);
$stmt->execute(['id' => 1]);
$user = $stmt->fetch();


MySQLi 预处理语句


$sql = "SELECT * FROM users WHERE id = ?";
$stmt = $conn->prepare($sql);
$stmt->bind_param("i", 1); // "i" 表示整数类型
$stmt->execute();
$result = $stmt->get_result();
$user = $result->fetch_assoc();


5. 错误处理
PDO 错误处理
PDO 默认使用静默模式,需要通过 setAttribute 启用异常模式:


$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);


MySQLi 错误处理
MySQLi 默认抛出错误,可以通过 mysqli_report 启用异常模式:


mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);


6. 事务处理
PDO 事务处理


$conn->beginTransaction();
try {
   $conn->exec("INSERT INTO users (username, email) VALUES ('Alice', 'alice@example.com')");
   $conn->exec("UPDATE accounts SET balance = balance - 100 WHERE user_id = 1");
   $conn->commit();
} catch (PDOException $e) {
   $conn->rollBack();
   echo "事务失败: " . $e->getMessage();
}


MySQLi 事务处理


$conn->begin_transaction();
try {
   $conn->query("INSERT INTO users (username, email) VALUES ('Alice', 'alice@example.com')");
   $conn->query("UPDATE accounts SET balance = balance - 100 WHERE user_id = 1");
   $conn->commit();
} catch (mysqli_sql_exception $e) {
   $conn->rollback();
   echo "事务失败: " . $e->getMessage();
}


7. 选择建议
选择 PDO 的场景:

需要支持多种数据库。

希望代码具有更好的可移植性。

喜欢简洁一致的 API。

选择 MySQLi 的场景:

仅使用 MySQL 数据库。

需要 MySQL 特有的功能(如异步查询、多语句执行等)。

对性能有较高要求。

总结
如果你需要跨数据库兼容性,或者希望代码更简洁,推荐使用 PDO。

如果你只使用 MySQL,并且需要更丰富的功能,推荐使用 MySQLi。

  • 登录或注册以发表评论
  • 33 次浏览
内容类型分类
数据库
文章归类
关系型数据库

文章标签

  • Mysql

评论

最新文章

  • 内容审核通知 content_moderation_notifications 模块简介
  • 调度程序 scheduler 模块简介
  • 工作流当中的草稿,已发布,很好理解,已归档是怎么理解。
  • 你行网 https://www.dwoke.com seo 关键词
  • brew 是什么命令
  • drupal 9 或 drpal 10 国内内容分享模块 Will Nice social share
  • Views Slideshow - Views Vanilla JavaScript Slideshow (VVJS) 简介和安装方法
  • drupal 11 安装statistics 统计模块
  • drupal11 扩展中找不到Statistics模块
  • drupal11 设置中的“总结摘要”和“切边的” 有什么区别

标签云

adsenseAIapacheaptbadblocksbreadcrumbbrewcentoscertbotckeditorcommandcomposercookiecsharpCSScurlC语言DDEVdiffdnsdockerDreamweaverDrupaldrupal 7drupal 8drupal 9drupal10drupal 11drushExcelfirewalldfirmwareflameshotformgimpgitgzipHTMLHTML5httpdhttp验证inputipjavaJavaScriptJavaSrciptkernelKVMLinuxmavenmbstringmod_expires 模块Mysqlnerdtreenetstatnetworknginxnpmpasswordphpphpmyadminphp扩展RFIDRSSselinuxSEOsharesimple_adsensesshsslStatisticssuperfishsurroundtagcloudstitleubuntuuploadprogressvimVPNVUEWireGuardwpsxdebugyoutubeyumzip主题(theme)二进制五笔分类术语压缩解压哈希值声音字段密码工作流快捷键摄影权限果树种植标签优化模块(module)源地址版本号电子秤电脑基础电脑技巧短信验证端口简介算法网站备份网站运营翻译英语表单视图(views)计算机基础赚钱超五类线网线邮件验证重定向重定向,301错误颜色

相关文章

  • 在PHP中判断数据库是否存在并新建数据库
  • information_schema.SCHEMATA 详解
  • MySQL 验证数据库是否存在的方法
  • MySQL 中常见的数据类型及其使用范围、大小和默认值
  • MySQL 关键字及其作用
  • 在mysql 数据库中,什么是启用外键约束
  • 在终端输入mysql命令回车后不能修改的问题
  • 创建用户信息表的SQL语句解释
  • 如何查看mysql 端口命令
  • phpmysql 在登录后显示“使用配置文件中定义的控制用户连接失败”问题的解决方法
RSS源

关于我们

  • 你行网简介
  • 关于我们
  • 版权声明

网站相关

  • 社区论坛
  • 网址导航
  • 网站地图
  • 联系我们

友情链接

  • 英文学习

友情链接2

  • drupal 大学
  • 水滴间
  • 爱码网
  • Apache

友情链接3

  • MySQL
  • php
  • drupalcode

友情链接4

  • Drupal 中国
  • Drupal 老葛
  • 宁浩网
  • drupal 台湾
Copyright © 2019 - 2021 你行网 版权所有  粤ICP备19072650号-1