PHP+MySQL分页处理的探讨

php中文网
发布: 2016-06-07 16:52:41
原创
1090人浏览过

常见的分页处理流程为: 1、用select count(*) from tbl_name取得待分页的总记录数 2、根据每页的记录数计算出总页数:总页数 =

常见的分页处理流程为: 1、用select count(*) from tbl_name取得待分页的总记录数 2、根据每页的记录数计算出总页数:总页数 = ceil(总记录数/每页记录数) 3、根据当前页号计算出起始位置:起始位置 = (当前页号-1)*每页记录数 4、用select * from tbl_name limit 起始位置,每页记录数 取得待显示记录 5、列表输出相关信息 在这个流程中,数据库需要两次遍历表才能得到所需数据。尽管limit会在得到指定记录数后会终止遍历,但前面直到“起始位置”的检索是浪费掉的。

这里提出一种新算法与大家讨论: 1、利用mysql的用户变量,分割并提取每页起始的id号。 2、查询结果的记录数即为总页数 3、根据当前页号取得当前页的起始id 4、用select * from tbl_name where id>=起始id limit 每页记录数 取得待显示记录 5、列表输出相关信息 可以看到,在后一次查询中。由于利用了id作为主键的特征,数据库可直接定位到所需记录。从而减少了查询时间。 这个查询算法有一个副产品:可以产生一条用于衔接上下页的重复记录,,也就是各页间有一条重叠的记录。当然,去掉他也是很容易的。 以下是测试代码:

=";

}

if($mode) $pagesize++;

mysql_query("set @v:=-1"); // 定义mysql用户变量

$rs = mysql_query("select @v:=(@v+1) as xh, id from data HAVING mod(xh,$pagesize)=0 order by id $order");

mysql_result_all($rs); // 检查各页分布

echo $pages = mysql_num_rows($rs); // 取得总页数

if($mode) $pagesize--;

// 测试分页结果,$i表示显示页

for($i=0;$imysql_result_all.inc 这个函数我贴过多次了,对调试程序非常有用的。 ";

for($i=0;$i".mysql_field_name($result,$i).""; } echo ""; while($row = mysql_fetch_row($result)) { echo ""; for($i=0;$i"; } echo ""; } echo ""; } ?>

linux

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号