跳转到主要内容
你行网

Main navigation

  • 首页
  • 文章
  • 教程
  • 视频
  • 下载
  • 社区
  • 网站导航
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。

标签

  • php
  • 登录或注册以发表评论

评论

相关文章

PHP数据类型及其作用总结
php过滤器的作用和说明
php 会话使用方法
什么是PHPSTORM_META
php 数据类型和使用范围大小,和默认值
为什么session_start() 不用带参数
session_start(); 连接数据库前为什么要启用会话。
pdo连接方法和错误处理
php的注释符号使用
类的自动加载是怎样去实现的。
一套框架的生命周期是多久
什么是类?
怎么实现一个静态化常用的设计模式
什么是面向对象,其主要特征是什么。
转义用户输入的特殊字符有哪些函数
语句中include和request区别是什么。
error repoting 函数的作用是什么
PHP中isset和empty的区别
move_uploaded_file 参数说明
PHP APCu 缓存设置建议

文章标签

CSS
Excel
ubuntu
php
五笔
vim
Linux
HTML
command
drupal 7
composer
centos
Mysql
drupal 8
模块(module)
VPN
drush
JavaSrcipt
apache
drupal 9
英语
Drupal
SEO
nerdtree
network
果树种植
surround
drupal10
主题(theme)
phpmyadmin
ssh
权限
yum
二进制
声音
ssl
selinux
HTML5
用户
password
Dreamweaver
flameshot
颜色
翻译
uploadprogress
DDEV
视图(views)
firewalld
gzip
快捷键
kernel
xdebug
错误
ckeditor
mbstring
C语言
源地址
简介
php扩展
电脑基础
certbot
git
apt
压缩解压
表单
电子秤
httpd
WireGuard
邮件验证
breadcrumb
AI
superfish
diff
重定向
网站备份
摄影
tagclouds
docker
java
csharp
短信验证
adsense
drupal9
电脑技巧
simple_adsense
算法
RSS
youtube
版本号
JavaScript
badblocks
端口
cookie
VUE
网站运营
计算机基础
gimp
form
mod_expires 模块
nginx
zip
http验证
重定向,301
curl
netstat
input
赚钱
ip
dns
RFID
标签优化
drupal11
maven
drupal 11
npm
哈希值
字段
更多
RSS源
本站由阿里云强力驱动,幸运券优惠链接
Copyright © 2019 - 2021 你行网 版权所有  粤ICP备19072650号