PHP 连接 MySQL
PHP 5 及更高版本可以使用以下方式与 MySQL 数据库协同工作:
- MySQLi 扩展("i" 代表 improved,即改进)
- PDO(PHP Data Objects,即 PHP 数据对象)
早期版本的 PHP 使用了 MySQL 扩展。但是,该扩展已于 2012 年弃用。
我应该使用 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 面向对象)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
// 创建连接
$conn = new mysqli($servername, $username, $password);
// 检查连接
if ($conn->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 过程式)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
// 创建连接
$conn = mysqli_connect($servername, $username, $password);
// 检查连接
if (!$conn) {
die("连接失败:" . mysqli_connect_error());
}
echo "成功连接";
?>
实例(PDO)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
try {
$conn = new PDO("mysql:host=$servername;dbname=myDB", $username, $password);
// 将 PDO 错误模式设置为异常
$conn->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;