菜单
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

PHP 教程

PHP HOME PHP 简介 PHP 安装 PHP 语法 PHP 注释 PHP 变量 PHP Echo / Print PHP 数据类型 PHP 字符串 PHP 数字 PHP 类型转换 PHP 数学 PHP 常量 PHP 魔术常量 PHP 运算符 PHP If...Else...Elseif PHP Switch PHP 循环 PHP 函数 PHP 数组 PHP 超全局变量 PHP 正则表达式

PHP 表单

PHP 表单处理 PHP 表单验证 PHP 表单必填项 PHP 表单 URL/电子邮件 PHP 表单完成

PHP 高级

PHP 日期和时间 PHP Include PHP 文件处理 PHP 文件打开/读取 PHP 文件创建/写入 PHP 文件上传 PHP Cookies PHP Sessions PHP 过滤器 PHP 高级过滤器 PHP 回调函数 PHP JSON PHP 异常

PHP OOP

PHP 什么是 OOP PHP 类/对象 PHP 构造函数 PHP 析构函数 PHP 访问修饰符 PHP 继承 PHP 常量 PHP 抽象类 PHP 接口 PHP Trait PHP 静态方法 PHP 静态属性 PHP 命名空间 PHP 可迭代对象

MySQL 数据库

MySQL 数据库 MySQL 连接 MySQL 创建数据库 MySQL 创建表 MySQL 插入数据 MySQL 获取最后 ID MySQL 插入多条数据 MySQL 预处理 MySQL 查询数据 MySQL Where MySQL Order By MySQL 删除数据 MySQL 更新数据 MySQL 限制数据

PHP XML

PHP XML 解析器 PHP SimpleXML 解析器 PHP SimpleXML - 获取 PHP XML Expat PHP XML DOM

PHP - AJAX

AJAX 简介 AJAX PHP AJAX 数据库 AJAX XML AJAX 实时搜索 AJAX 投票

PHP 示例

PHP 示例 PHP 编译器 PHP 测验 PHP 练习 PHP 服务器 PHP 证书

PHP 参考手册

PHP 概述 PHP 数组 PHP 日历 PHP 日期 PHP 目录 PHP 错误 PHP 异常 PHP 文件系统 PHP 过滤器 PHP FTP PHP JSON PHP 关键词 PHP Libxml PHP 邮件 PHP 数学 PHP 杂项 PHP MySQLi PHP 网络 PHP 输出控制 PHP 正则表达式 PHP SimpleXML PHP Stream PHP String PHP 变量处理 PHP XML 解析器 PHP 压缩 PHP 时区

PHP 连接到 MySQL


PHP 5 及更高版本可以使用以下方式处理 MySQL 数据库:

  • MySQLi 扩展("i" 代表 improved,即改进版)
  • PDO(PHP Data Objects)

早期版本的 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 扩展会自动安装。

有关安装详细信息,请访问: https://php.ac.cn/manual/en/mysqli.installation.php


PDO 安装

有关安装详细信息,请访问: https://php.ac.cn/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 "Connected successfully";
?>

上面面向对象的示例说明

$connect_error 在 PHP 5.2.9 和 5.3.0 之前是无效的。如果你需要确保与 5.2.9 和 5.3.0 之前的 PHP 版本兼容,请使用以下代码代替:

// 检查连接
if (mysqli_connect_error()) {
  die("Database connection failed: " . mysqli_connect_error());
}

示例(MySQLi 过程式)

<?php
$servername = "localhost";
$username = "username";
$password = "password";

// 创建连接
$conn = mysqli_connect($servername, $username, $password);

// 检查连接
if (!$conn) {
  die("Connection failed: " . mysqli_connect_error());
}
echo "Connected successfully";
?>

示例(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 "Connected successfully";
} catch(PDOException $e) {
  echo "Connection failed: " . $e->getMessage();
}
?>

注意: 在上面的 PDO 示例中,我们还**指定了一个数据库 (myDB)**。PDO 需要一个有效的数据库才能连接。如果未指定数据库,将抛出异常。

提示: PDO 的一个巨大好处是它有一个异常类来处理数据库查询中可能发生的任何问题。如果在 try{ } 块中抛出异常,脚本将停止执行并直接跳转到第一个 catch(){ } 块。


关闭连接

脚本结束时连接将自动关闭。要提前关闭连接,请使用以下方法:

MySQLi 面向对象

$conn->close();

MySQLi 过程式

mysqli_close($conn);

PDO

$conn = null;


×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持