PHP分页常用两种方法:一是基于SQL LIMIT和OFFSET的手动分页,适用于数据量适中场景,通过$page、$per_page、$offset计算并配合COUNT(*)求总页数;二是游标分页,利用唯一有序字段(如id或created_at)避免OFFSET性能问题,适合大数据量高并发场景。

如果您在开发PHP网站时需要展示大量数据,但希望避免一次性加载全部内容导致页面卡顿或用户体验下降,则分页显示是常用且必要的交互方案。以下是实现PHP分页功能的多种方法:
一、基于SQL LIMIT和OFFSET的手动分页
该方法通过在MySQL查询中使用LIMIT和OFFSET控制每次获取的数据范围,配合URL参数动态计算起始位置,适用于数据量适中、无频繁删除场景。
1、在PHP脚本中获取当前页码,使用$_GET['page']并进行整型过滤与默认值设置,确保$page = max(1, (int)$_GET['page'])。
2、设定每页显示条数,例如$per_page = 10。
立即学习“PHP免费学习笔记(深入)”;
3、计算SQL中的OFFSET值:$offset = ($page - 1) * $per_page。
4、执行查询语句:SELECT * FROM articles ORDER BY id DESC LIMIT $per_page OFFSET $offset。
5、使用COUNT(*)单独查询总记录数,用于计算总页数:$total = $pdo->query("SELECT COUNT(*) FROM articles")->fetchColumn()。
6、生成页码HTML链接,对当前页做禁用处理,其余页码以?page=1、?page=2等形式输出。
二、基于游标分页(Cursor-based Pagination)
该方法利用有序字段(如时间戳或自增ID)作为游标锚点,避免OFFSET在大数据量下性能衰减,适合高并发、实时性要求高的列表场景。
1、要求数据表中存在唯一且单调递增/递减的字段,例如created_at或id。
2、首次请求不带游标参数,取最新10条:SELECT * FROM posts ORDER BY id DESC LIMIT 11。
3、若返回11条,则第11条的id作为下一页游标,URL中传递cursor=12345。
4、下一页查询改为:SELECT * FROM posts WHERE id
5、必须在id字段上建立索引,否则WHERE条件将引发全表扫描。
标签: mysql php javascript java html js 前端 json ajax 大数据 后端 sql注入
还木有评论哦,快来抢沙发吧~