php代码实现分页效果主要依赖数据库查询时的偏移量和限制条数参数,结合前端页码交互完成数据分段展示,下面先介绍基础实现逻辑。

基础分页效果实现步骤
1. 获取页码与分页参数
首先需要从请求中获取当前页码,同时定义每页展示的数据条数,还要处理页码不合法的情况,比如页码小于1时默认设为1。
<?php
// 每页展示10条数据
$pageSize = 10;
// 获取当前页码,默认第一页
$page = isset($_GET['page']) ? intval($_GET['page']) : 1;
// 页码最小为1
if ($page < 1) {
$page = 1;
}
?>
2. 计算查询偏移量
数据库查询时使用limit和offset参数,偏移量等于(当前页码-1)乘以每页条数,这样就能定位到当前页需要查询的数据起始位置。
<?php // 计算偏移量 $offset = ($page - 1) * $pageSize; ?>
3. 执行分页查询
拼接带分页参数的sql语句,查询当前页的数据,同时可以单独查询总数据条数,用来计算总页数。
<?php
// 假设已经建立数据库连接,$conn是连接对象
// 查询当前页数据
$sql = "SELECT id, title, content FROM article LIMIT $pageSize OFFSET $offset";
$result = mysqli_query($conn, $sql);
$list = [];
while ($row = mysqli_fetch_assoc($result)) {
$list[] = $row;
}
// 查询总数据条数
$countSql = "SELECT COUNT(*) as total FROM article";
$countResult = mysqli_query($conn, $countSql);
$countRow = mysqli_fetch_assoc($countResult);
$total = $countRow['total'];
// 计算总页数
$totalPage = ceil($total / $pageSize);
?>
4. 生成页码导航
根据总页数和当前页码,生成前翻、后翻以及页码按钮,方便用户切换页面。
<?php
// 生成页码导航
echo '<div class="page-nav">';
// 上一页
if ($page > 1) {
echo '<a href="?page=' . ($page - 1) . '">上一页</a>';
}
// 页码按钮,这里简单展示1到总页数的按钮
for ($i = 1; $i <= $totalPage; $i++) {
if ($i == $page) {
echo '<span class="current">' . $i . '</span>';
} else {
echo '<a href="?page=' . $i . '">' . $i . '</a>';
}
}
// 下一页
if ($page < $totalPage) {
echo '<a href="?page=' . ($page + 1) . '">下一页</a>';
}
echo '</div>';
?>
php分页实现的优化方案
1. 数据库索引优化
分页查询时如果表数据量大,没有索引的话查询会很慢,尤其是偏移量很大的时候。可以给查询条件的字段和排序字段添加索引,比如上面的查询如果按id排序,给id加主键索引就能大幅提升查询速度。
2. 延迟关联优化大偏移量分页
当查询的偏移量很大时,比如查询第1000页的数据,limit 10 offset 9990会先扫描前9990条数据再取后面的10条,效率很低。可以用延迟关联的方式,先通过索引查询到主键id,再关联原表查询需要的字段。
<?php
// 延迟关联优化分页查询
$sql = "SELECT a.id, a.title, a.content FROM article a INNER JOIN (SELECT id FROM article ORDER BY id LIMIT $pageSize OFFSET $offset) b ON a.id = b.id";
$result = mysqli_query($conn, $sql);
$list = [];
while ($row = mysqli_fetch_assoc($result)) {
$list[] = $row;
}
?>
3. 缓存分页数据
如果分页数据更新不频繁,可以把分页结果缓存起来,比如使用redis缓存,缓存键可以包含页码和每页条数,设置合适的过期时间,减少数据库查询次数。
<?php
// 简单的redis缓存示例,假设已经安装redis扩展并连接
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$cacheKey = "article_page_{$page}_size_{$pageSize}";
// 先查缓存
$cacheData = $redis->get($cacheKey);
if ($cacheData) {
$list = json_decode($cacheData, true);
} else {
// 执行上面的分页查询逻辑
$sql = "SELECT id, title, content FROM article LIMIT $pageSize OFFSET $offset";
$result = mysqli_query($conn, $sql);
$list = [];
while ($row = mysqli_fetch_assoc($result)) {
$list[] = $row;
}
// 缓存1小时
$redis->setex($cacheKey, 3600, json_encode($list));
}
?>
4. 限制最大可查询页码
避免用户传入过大的页码导致偏移量过大,可以在获取页码时判断,如果页码超过总页数就返回第一页或者提示无数据,同时可以设置最大可查询的页码,比如最多只能查前100页,减少无效的大偏移量查询。