当前位置: 首页> 最新文章列表> 使用PHP和SQLite实现分页和搜索功能

使用PHP和SQLite实现分页和搜索功能

M66 2025-06-06

PHP与SQLite实现分页与搜索功能简介

在Web开发中,分页与搜索功能是不可或缺的一部分,特别是在处理大量数据展示时。使用轻量级的SQLite结合PHP,可以快速搭建一个查询性能良好、结构清晰的功能模块。本文将通过示例代码介绍如何构建这一系统。

创建SQLite数据库及数据表

首先,需要建立一个SQLite数据库并创建一个存储用户信息的表,示例如下:

CREATE TABLE users (
    id INTEGER PRIMARY KEY,
    name TEXT,
    age INTEGER
);

PHP代码实现分页与搜索功能

接下来是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的组合,我们成功实现了分页与搜索功能的基本框架。在实际项目中,还可以进一步优化:

  • 为搜索结果添加排序逻辑
  • 结合AJAX技术实现无刷新搜索
  • 对用户输入进行更严格的过滤,防止SQL注入

本教程展示的是一套可运行、可扩展的基础结构,适合用于小型项目或原型开发。