在PHP中读取数据库表是Web开发中的常见操作,通常通过扩展如MySQLi或PDO来实现,以下是详细步骤和代码示例,帮助理解如何高效读取数据库表数据。

确保已安装PHP和相应的数据库(如MySQL),并已创建数据库和表,以MySQLi扩展为例,步骤包括连接数据库、执行查询、获取结果以及处理数据,连接数据库需要服务器地址、用户名、密码和数据库名,使用mysqli_connect()函数建立连接,并通过mysqli_select_db()选择数据库,连接成功后,使用mysqli_query()执行SQL查询语句,如SELECT * FROM table_name,查询结果通过mysqli_fetch_array()或mysqli_fetch_assoc()逐行获取,前者返回索引和关联数组,后者仅返回关联数组,遍历结果集后,需使用mysqli_free_result()释放内存,并通过mysqli_close()关闭连接。
以下是一个完整示例代码:
<?php
// 连接数据库
$servername = "localhost";
$username = "root";
$password = "123456";
$dbname = "test_db";
$conn = mysqli_connect($servername, $username, $password, $dbname);
if (!$conn) {
die("连接失败: " . mysqli_connect_error());
}
// 执行查询
$sql = "SELECT id, name, email FROM users";
$result = mysqli_query($conn, $sql);
// 检查结果集是否为空
if (mysqli_num_rows($result) > 0) {
// 输出数据
while($row = mysqli_fetch_assoc($result)) {
echo "ID: " . $row["id"]. " - Name: " . $row["name"]. " - Email: " . $row["email"]. "<br>";
}
} else {
echo "0 结果";
}
// 释放结果集
mysqli_free_result($result);
// 关闭连接
mysqli_close($conn);
?>
使用PDO扩展时,步骤类似,但语法略有不同,PDO支持多种数据库,具有更好的可移植性,连接数据库通过new PDO()实现,执行查询使用query()方法,获取结果通过fetch()或fetchAll(),PDO的优势在于预处理语句,可防止SQL注入攻击,示例代码如下:

<?php
// 连接数据库
$servername = "localhost";
$username = "root";
$password = "123456";
$dbname = "test_db";
try {
$conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
// 执行查询
$stmt = $conn->query("SELECT id, name, email FROM users");
// 获取结果
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
echo "ID: " . $row["id"]. " - Name: " . $row["name"]. " - Email: " . $row["email"]. "<br>";
}
} catch(PDOException $e) {
echo "错误: " . $e->getMessage();
}
// 关闭连接
$conn = null;
?>
在实际开发中,处理大量数据时需注意性能优化,使用分页查询减少单次加载的数据量,或通过索引提高查询速度,错误处理至关重要,应使用try-catch捕获异常,避免敏感信息泄露,以下是一个分页查询的示例:
<?php
$page = isset($_GET['page']) ? (int)$_GET['page'] : 1;
$perPage = 10;
$offset = ($page - 1) * $perPage;
$conn = new PDO("mysql:host=localhost;dbname=test_db", "root", "123456");
$stmt = $conn->prepare("SELECT id, name, email FROM users LIMIT :offset, :perPage");
$stmt->bindValue(':offset', $offset, PDO::PARAM_INT);
$stmt->bindValue(':perPage', $perPage, PDO::PARAM_INT);
$stmt->execute();
$results = $stmt->fetchAll(PDO::FETCH_ASSOC);
foreach ($results as $row) {
echo "ID: " . $row["id"]. " - Name: " . $row["name"]. "<br>";
}
?>
以下是数据读取的常见操作对比:
| 操作类型 | MySQLi 方法 | PDO 方法 | 说明 |
|---|---|---|---|
| 连接数据库 | mysqli_connect() | new PDO() | 建立与数据库的连接 |
| 执行查询 | mysqli_query() | $conn->query() | 执行SQL语句并返回结果集 |
| 获取单行数据 | mysqli_fetch_assoc() | $stmt->fetch(PDO::FETCH_ASSOC) | 获取一行数据作为关联数组 |
| 获取所有数据 | mysqli_fetch_all() | $stmt->fetchAll() | 获取所有数据并返回数组 |
| 释放结果集 | mysqli_free_result() | 无需手动释放 | 释放内存资源 |
| 关闭连接 | mysqli_close() | $conn = null | 断开数据库连接 |
相关问答FAQs:

-
问:PHP读取数据库时如何防止SQL注入?
答:使用预处理语句(Prepared Statements)是防止SQL注入的最佳方式,MySQLi中通过mysqli_prepare()和bind_param()实现,PDO中通过prepare()和bindValue()或bindParam()实现,预处理语句将SQL语句和数据分开处理,避免恶意代码注入。// PDO示例 $stmt = $conn->prepare("SELECT * FROM users WHERE name = :name"); $stmt->bindParam(':name', $name); $stmt->execute(); -
问:如何处理大数据量的查询结果?
答:对于大数据量,建议使用分页查询或流式处理,分页通过LIMIT和OFFSET实现,如LIMIT 10 OFFSET 20表示从第21条数据开始取10条,流式处理通过逐行获取数据(如fetch())而非一次性加载所有数据,减少内存占用,可使用PDO::ATTR_CURSOR => PDO::CURSOR_SCROLL实现滚动结果集,但需注意性能影响。
来源互联网整合,作者:小编,如若转载,请注明出处:https://www.aiboce.com/ask/248227.html