在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的组合,我们成功实现了分页与搜索功能的基本框架。在实际项目中,还可以进一步优化:
本教程展示的是一套可运行、可扩展的基础结构,适合用于小型项目或原型开发。