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;