技术文摘
PHP 如何获取 MySQL 数据库记录数据
2025-01-14 23:30:54 小编
PHP 如何获取 MySQL 数据库记录数据
在 Web 开发中,PHP 与 MySQL 数据库的搭配十分常见。获取 MySQL 数据库中的记录数据是一项基础且关键的操作,下面就详细介绍相关方法。
要使用 PHP 获取 MySQL 数据,需要建立数据库连接。利用 mysqli 或 PDO 扩展都能实现。以 mysqli 为例,代码如下:
<?php
$servername = "localhost";
$username = "your_username";
$password = "your_password";
$dbname = "your_database_name";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检查连接
if ($conn->connect_error) {
die("连接失败: ". $conn->connect_error);
}
?>
连接成功后,便可以编写 SQL 查询语句来获取数据。例如,从名为 users 的表中获取所有记录:
SELECT * FROM users;
在 PHP 中执行该查询,可使用 query() 方法:
$result = $conn->query("SELECT * FROM users");
若查询成功,$result 将是一个包含结果集的对象。接下来,要从结果集中获取数据,有多种方式。使用 fetch_assoc() 方法可以按关联数组形式获取记录,示例代码如下:
if ($result->num_rows > 0) {
while ($row = $result->fetch_assoc()) {
echo "ID: ". $row["id"]. " - 姓名: ". $row["name"]. "<br>";
}
} else {
echo "没有找到记录";
}
fetch_assoc() 会将每行数据作为关联数组返回,数组的键是表中的列名。
还可以使用 fetch_row() 按索引数组获取记录,不过此时需要通过数字索引来访问数据。示例如下:
if ($result->num_rows > 0) {
while ($row = $result->fetch_row()) {
echo "ID: ". $row[0]. " - 姓名: ". $row[1]. "<br>";
}
} else {
echo "没有找到记录";
}
另外,PDO 扩展也是不错的选择,它提供了更统一的 API 来操作不同数据库。使用 PDO 获取 MySQL 数据,首先要创建 PDO 实例:
try {
$pdo = new PDO("mysql:host=localhost;dbname=your_database_name", "your_username", "your_password");
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch(PDOException $e) {
echo "连接失败: ". $e->getMessage();
}
然后执行查询并获取结果:
$stmt = $pdo->query("SELECT * FROM users");
$result = $stmt->fetchAll(PDO::FETCH_ASSOC);
foreach ($result as $row) {
echo "ID: ". $row["id"]. " - 姓名: ". $row["name"]. "<br>";
}
掌握这些方法,就能在 PHP 项目中轻松获取 MySQL 数据库中的记录数据,为开发强大的 Web 应用奠定坚实基础。
- 鸿蒙 OS 蓝牙耳机电量查看方法及技巧
- Ubuntu14.04 中 apt-get install 报错与解决之道
- 华为鸿蒙系统一键抠图方法及技巧
- Ubuntu17.10 桌面显示图标的方法
- Ubuntu 17.10 最新版动态工作区的使用方法
- 鸿蒙系统纯净模式的退出方法及步骤教程
- 鸿蒙系统自定义图标方法及样式修改
- 华为鸿蒙一键抠图的使用方法教程
- Ubuntu 利用 wine 安装 QQ 无法输入账号的解决办法
- Ubuntu 系统中 WPS 无法输入中文的解决办法
- 鸿蒙绑定电子身份证的方法
- Ubuntu 挂载移动硬盘时出现 exfat 文件系统类型未知错误
- 华为下载鸿蒙描述文件无法升级系统如何解决
- Ubuntu 磁盘空间快速释放的七种途径
- Ubuntu 系统中 IP 地址的设置方法