php分页代码简单实现原理,PHP 分页代码与分页原理解析

本文章来给各位php入门者提供在php与mysql实现分页代码与原理,在mysql中支持limit 0,1这样就是查询0,1条记录了,有了它在php中分页就简单快速多了。

所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:

每页多少条记录($PageSize)?

当前是第几页($CurrentPageID)?

现在只要再给我一个结果集,我就可以显示某段特定的结果出来。

至于其他的参数,比如:上一页($PreviousPageID)、下一页($NextPageID)、总页数($numPages)等等,都可以根据前边这几个东西得到。

以MySQL数据库为例,如果要从表内截取某段内容,sql语句可以用:select * from table limit offset, rows。看看下面一组sql语句,尝试一下发现其中的规率。

 代码如下复制代码
select * from table limit 0,10 // 前10条记录

select * from table limit 10,10 // 第11至20条记录

select * from table limit 20,10 // 第21至30条记录

……

这一组sql语句其实就是当$PageSize=10的时候取表内每一页数据的sql语句,我们可以总结出这样一个模板:

 代码如下复制代码

select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize

拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事。搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用php从数据库内获取数据并显示了。以下我将用具体代码加以说明。

 代码如下复制代码

ShowData

ShowData

//连接数据库

$page = 1;

$db = mysql_connect('127.0.0.1','root','toor');

mysql_select_db('test',$db);

$pagesize = 3;    //每页显示到数量

//计算一共有多少记录,用于计算页数

$rs = mysql_query("select count(*) from info",$db);

$row = @mysql_fetch_array($rs);

$numrows = $row[0];

//计算页数

$pages = intval($numrows / $pagesize);

if ($numrows % $pagesize)

{

$pages ;

}

//设置页数

if (isset($_GET['page']))

{

$page = intval($_GET['page']);

}

else

{

$page = 1;        //其他情况,都指向第一页

}

//计算记录的偏移量

$offset = $pagesize * ($page - 1);

//读取指定记录

$rs = mysql_query("select * from info order by id limit $offset,$pagesize",$db);

//把数据用表格显示出来

if ($row = @mysql_fetch_array($rs))

{

$i = 0;

?>

ID

DOC

do{

$i ;

?>

=$row['id']?>=$row['doc']?>

}

//循环显示数据

while ($row = mysql_fetch_array($rs));

echo "

";

}

echo "

共".$pages."页(".$page."/".$pages.")";

for ($i = 1;$i < $page;$i )

{

echo "[".$i."]";

}

echo "[".$page."]";

for ($i = $page 1;$i <= $pages;$i )

{

echo "[".$i."]";

}

echo "

";

?>

总结,分页就根据用户点击连接,然后由于php获取page值再经过一系列算法得出当前多少页面,然后取多少要就显示出你要查看的记录了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值