手册
目录
如果您需要一个简短的答案,那就是“随您喜欢”。
MySQLi 和 PDO 都有各自的优点:
PDO 可以在 12 个不同的数据库系统上工作,而 MySQLi 仅能与 MySQL 数据库协同工作。
因此,如果您必须将项目切换到使用另一个数据库,PDO 会使该过程变得简单。您只需更改连接字符串和几个查询即可。而使用 MySQLi,您将需要重写整个代码 - 包括查询。
两者都是面向对象的,但 MySQLi 还提供了一个过程式 API。
两者都支持预处理语句。预处理语句可以防止 SQL 注入,对于 Web 应用程序的安全性非常重要。
在本章和后续章节中,我们将展示使用 PHP 和 MySQL 协同工作的三种方式:
对于 Linux 和 Windows:在大多数情况下,当安装 php5 mysql 包时,MySQLi 扩展会自动安装。
有关安装详细信息,请访问:http://php.net/manual/en/mysqli.installation.php
有关安装详细信息,请访问:http://php.net/manual/en/pdo.installation.php
在我们可以访问 MySQL 数据库中的数据之前,我们需要能够连接到服务器:
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());
}
setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
echo "成功连接";
} catch(PDOException $e) {
echo "连接失败:" . $e->getMessage();
}
?>
注意:在上面的 PDO 示例中,我们还指定了一个数据库(myDB)。PDO 需要连接到一个有效的数据库。如果没有指定数据库,则会抛出异常。
提示:PDO 的一个巨大优势是,它有一个异常类来处理可能在我们的数据库查询中发生的任何问题。如果在 try{ } 块中抛出异常,脚本将停止执行并直接流向第一个 catch(){ } 块。
当脚本结束时,连接将自动关闭。若要在之前关闭连接,请使用以下方式:
$conn->close();
mysqli_close($conn);
$conn = null;
相关
视频
RELATED VIDEOS
科技资讯
1
2
3
4
5
6
7
8
9
精选课程
共5课时
17.2万人学习
共49课时
77万人学习
共29课时
61.7万人学习
共25课时
39.3万人学习
共43课时
70.9万人学习
共25课时
61.6万人学习
共22课时
23万人学习
共28课时
33.9万人学习
共89课时
125万人学习