PHP 分页代码与分页原理解析
发布:smiling 来源: PHP粉丝网 添加日期:2014-01-06 11:24:51 浏览: 评论:0
本文章来给各位php入门者提供在php与mysql实现分页代码与原理,在mysql中支持limit 0,1这样就是查询0,1条记录了,有了它在php中分页就简单快速多了。
所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:1,每页多少条记录($PageSize)2,当前是第几页($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从数据库内获取数据并显示了,以下我将用具体代码加以说明.
- <html>
- <head>
- <title>
- ShowData
- </title>
- </head>
- <body>
- <h2>ShowData</h2>
- <?php
- //连接数据库
- $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;
- ?>
- <table border='0' width='80%'>
- <tr>
- <td width='50%'>
- <p align='center'>ID</td>
- <td width='50%'>
- <p align='center'>DOC</td>
- </tr>
- <?php
- do{
- $i++;
- ?>
- <tr align='center'>
- <td width='50%'><?=$row['id']?></td>
- <td width='50%'><?=$row['doc']?></td>
- </tr>
- <?php
- }
- //循环显示数据
- while ($row = mysql_fetch_array($rs));
- echo "</table>";
- }
- echo "<div align='center'> 共".$pages."页(".$page."/".$pages.")";
- for ($i = 1;$i < $page;$i++)
- {
- echo "<a href='showdata.php?page=".$i."'>[".$i."]</a>";
- }
- echo "[".$page."]";
- for ($i = $page + 1;$i <= $pages;$i++)
- {
- echo "<a href='showdata.php?page=".$i."'>[".$i."]</a>";
- }
- echo "</div>";
- ?>
- </body>
- </html>
总结:分页就根据用户点击连接,然后由于php获取page值再经过一系列算法得出当前多少页面,然后取多少要就显示出你要查看的记录了。
Tags: PHP分页 代码 分页原理
- 上一篇:php长文章分页原理与实现程序
- 下一篇:php文章内容分页实例程序
相关文章
- ·php分页代码与分页原理(2013-11-12)
- ·PHP分页显示制作(2013-11-13)
- ·PHP实现翻页跳转功能(2013-11-13)
- ·自定义PHP分页函数(2013-11-13)
- ·小谈PHP&MYSQL分页原理及实现(2013-11-13)
- ·php中分页显示文章标题(2013-12-10)
- ·php文章内容分页实例程序(2014-01-07)
- ·php分页可利用表格来分页类(2014-01-15)
- ·简单入门级php分页代码(2014-05-10)
- ·php分页实例程序函数(2014-07-18)
- ·二个php分页程序代码(2014-07-29)
- ·php分页多种实现程序代码(2014-07-31)
- ·两款实用php分页代码(2014-08-15)
- ·经典php分页代码,支持数字偏移(2014-08-15)
- ·php分页代码(实用的分页程序)(2014-08-16)
- ·php分页代码(下一页 上一页)(2014-08-16)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)