在Web开发中,分页与搜索功能是不可或缺的一部分,特别是在处理大量数据展示时。使用轻量级的SQLite结合PHP,可以快速搭建一个查询性能良好、结构清晰的功能模块。本文将通过示例代码介绍如何构建这一系统。
首先,需要建立一个SQLite数据库并创建一个存储用户信息的表,示例如下:
CREATE TABLE users (
id INTEGER PRIMARY KEY,
name TEXT,
age INTEGER
);
接下来是PHP代码部分,负责接收用户输入、构建SQL语句并输出结果:
// 获取页码和搜索关键字
$page = isset($_GET['page']) ? intval($_GET['page']) : 1;
$keyword = isset($_GET['keyword']) ? $_GET['keyword'] : '';
// 计算分页偏移量
$offset = ($page - 1) * 10;
// 构建查询SQL语句
$sql = "SELECT * FROM users";
if ($keyword) {
$sql .= " WHERE name LIKE '%$keyword%'";
}
$sql .= " LIMIT 10 OFFSET $offset";
// 执行查询
$result = $conn->query($sql);
// 输出查询结果
if ($result->num_rows > 0) {
while ($row = $result->fetch_assoc()) {
echo "ID: " . $row['id'] . ", Name: " . $row['name'] . ", Age: " . $row['age'];
echo "<br>";
}
} else {
echo "没有找到匹配的结果";
}
// 计算总页数
$total = $conn->query("SELECT COUNT(*) FROM users")->fetch_row()[0];
$totalPages = ceil($total / 10);
// 输出分页链接
for ($i = 1; $i <= $totalPages; $i++) {
echo "<a href='?page=$i'>$i</a> ";
}
在前端页面中添加一个简单的搜索表单,供用户输入关键字:
<form action="" method="GET">
<input type="text" name="keyword">
<input type="submit" value="搜索">
</form>
通过上述PHP与SQLite的组合,我们成功实现了分页与搜索功能的基本框架。在实际项目中,还可以进一步优化:
本教程展示的是一套可运行、可扩展的基础结构,适合用于小型项目或原型开发。