分页显示是一种非常常见的浏览和显示大量数据的方法,属于web编程中最常处理的事件之一。对于web编程的老手来说,编写这种代码实在是和呼吸一样自然,但是对于初学者来说,常常对这个问题摸不着头绪,因此特地撰写此文对这个问题进行详细的讲解。
一、分页原理:
所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:
每页多少条记录($PageSize)? 当前是第几页($CurrentPageID)?
现在只要再给我一个结果集,我就可以显示某段特定的结果出来。
至于其他的参数,比如:上一页($PRevIoUsPageID)、下一页($NextPageID)、总页数($numPages)等等,都可以根据前边这几个东西得到。
以MysqL数据库为例,如果要从表内截取某段内容,sql语句可以用:select * from table limit offset,rows。看看下面一组sql语句,尝试一下发现其中的规率。
前10条记录:select * from table limit 0,10 第11至20条记录:select * from table limit 10,10 第21至30条记录:select * from table limit 20,10 …… 这一组sql语句其实就是当$PageSize=10的时候取表内每一页数据的sql语句,我们可以总结出这样一个模板: select * from table limit ($CurrentPageID - 1) * $PageSize,$PageSize 拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事。搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用PHP从数据库内获取数据并显示了。
二、分页代码说明:五个步骤
代码中有充分解释,可复制到自己记事本中直接使用
//4.13发送带有<a href="/tag/fenye/" target="_blank" class="keywords">分页</a>的<a href="/tag/sql/" target="_blank" class="keywords">sql</a>结果
$<a href="/tag/sql/" target="_blank" class="keywords">sql</a>="select * from emp limit $pageStart,$pageSize";//[根据$<a href="/tag/sql/" target="_blank" class="keywords">sql</a>语句的limit 后面的两个值(起始值,每页条数),来实现<a href="/tag/fenye/" target="_blank" class="keywords">分页</a>。以及求得这两个值。]
$res2=<a href="/tag/MysqL/" target="_blank" class="keywords">MysqL</a>_query($<a href="/tag/sql/" target="_blank" class="keywords">sql</a>,$conn) or die('无法<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>结果集'.<a href="/tag/MysqL/" target="_blank" class="keywords">MysqL</a>_error());
echo '<table border=1>';[ echo "<table border='1px' cellspacing='0px' bordercolor='red' width='600px'>";]
"<tr>
echo "<tr><td>{$row['id']}</td><td>{$row['name']}</td><td>{$row['grade']}</td><td>{$row['email']}</td><td>{$row['salary']}</td><td>删除用户</td><td>修改用户</td></tr>"; }
echo '</table>';
//4.14打印出页码的超链接
for($i=1;$i<=$pageCount;$i++){
echo "$i ";//[打印出页码的超链接]
}
//5.释放资源,关闭连接
mysql_free_result($res2);
mysql_close($conn);
?>