当前位置:Gxlcms > PHP教程 > php分页原理与页面跳转实例

php分页原理与页面跳转实例

时间:2021-07-01 10:21:17 帮助过:61人阅读

  1. select * from table limit 0,10 // 前10条记录
  2. select * from table limit 10,10 // 第11至20条记录
  3. select * from table limit 20,10 // 第21至30条记录
  4. ……

这一组sql语句其实就是当$pagesize=10的时候取表内每一页数据的sql语句,我们可以总结出这样一个模板: select * from table limit ($currentpageid - 1) * $pagesize, $pagesize 拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事。搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用php从数据库内获取数据并显示了。

php分页代码:

  1. // 建立数据库连接
  2. $link = mysql_connect("localhost", "mysql_user", "mysql_password")
  3. or die("could not connect: " . mysql_error());
  4. // 获取当前页数
  5. if( isset($_get['page']) ){
  6. $page = intval( $_get['page'] );
  7. }
  8. else{
  9. $page = 1;
  10. }
  11. // 每页数量
  12. $pagesize = 10;
  13. // 获取总数据量
  14. $sql = "select count(*) as amount from table";
  15. $result = mysql_query($sql);
  16. $row = mysql_fetch_row($result);
  17. $amount = $row['amount'];
  18. // 记算总共有多少页
  19. if( $amount ){
  20. if( $amount < $page_size ){ $page_count = 1; } //如果总数据量小于$pagesize,那么只有一页
  21. if( $amount % $page_size ){ //取总数据量除以每页数的余数
  22. $page_count = (int)($amount / $page_size) + 1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一
  23. }else{
  24. $page_count = $amount / $page_size;//如果没有余数,则页数等于总数据量除以每页数的结果
  25. }
  26. }
  27. else{
  28. $page_count = 0;
  29. }
  30. // 翻页链接
  31. $page_string = '';
  32. if( $page == 1 ){
  33. $page_string .= '第一页|上一页|';
  34. }
  35. else{
  36. $page_string .= '";第一页|上一页|';
  37. }
  38. if( ($page == $page_count) || ($page_count == 0) ){
  39. $page_string .= '下一页|尾页';
  40. }
  41. else{
  42. $page_string .= '下一页|尾页';
  43. }
  44. // 获取数据,以二维数组格式返回结果
  45. if( $amount ){
  46. $sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size";
  47. $result = mysql_query($sql);
  48. while ( $row = mysql_fetch_row($result) ){
  49. $rowset[] = $row;
  50. }
  51. }else{
  52. $rowset = array();
  53. }
  54. // 没有包含显示结果的代码,那不在讨论范围,只要用foreach就可以很简单的用得到的二维数组来显示结果
  55. ?>

oo风格代码,以下代码中的数据库连接是使用的pear db类进行处理

  1. // filename: pager.class.php
  2. // 分页类,这个类仅仅用于处理数据结构,不负责处理显示的工作
  3. class pager
  4. {
  5. var $pagesize; //每页的数量
  6. var $currentpageid; //当前的页数
  7. var $nextpageid; //下一页
  8. var $previouspageid; //上一页
  9. var $numpages; //总页数
  10. var $numitems; //总记录数
  11. var $isfirstpage; //是否第一页
  12. var $islastpage; //是否最后一页
  13. var $sql; //sql查询语句
  14. function pager($option)
  15. {
  16. global $db;
  17. $this->_setoptions($option);
  18. // 总条数
  19. if ( !isset($this->numitems) )
  20. {
  21. $res = $db->query($this->sql);
  22. $this->numitems = $res->numrows();
  23. }
  24. // 总页数
  25. if ( $this->numitems > 0 )
  26. {
  27. if ( $this->numitems < $this->pagesize ){ $this->numpages = 1; }
  28. if ( $this->numitems % $this->pagesize )
  29. {
  30. $this->numpages= (int)($this->numitems / $this->pagesize) + 1;
  31. }
  32. else
  33. {
  34. $this->numpages = $this->numitems / $this->pagesize;
  35. }
  36. }
  37. else
  38. {
  39. $this->numpages = 0;
  40. }
  41. switch ( $this->currentpageid )
  42. {
  43. case $this->numpages == 1:
  44. $this->isfirstpage = true;
  45. $this->islastpage = true;
  46. break;
  47. case 1:
  48. $this->isfirstpage = true;
  49. $this->islastpage = false;
  50. break;
  51. case $this->numpages:
  52. $this->isfirstpage = false;
  53. $this->islastpage = true;
  54. break;
  55. default:
  56. $this->isfirstpage = false;
  57. $this->islastpage = false;
  58. }
  59. if ( $this->numpages > 1 )
  60. {
  61. if ( !$this->islastpage ) { $this->nextpageid = $this->currentpageid + 1; }
  62. if ( !$this->isfirstpage ) { $this->previouspageid = $this->currentpageid - 1; }
  63. }
  64. return true;
  65. }
  66. /***
  67. *
  68. * 返回结果集的数据库连接
  69. * 在结果集比较大的时候可以直接使用这个方法获得数据库连接,然后在类之外遍历,这样开销较小
  70. * 如果结果集不是很大,可以直接使用getpagedata的方式获取二维数组格式的结果
  71. * getpagedata方法也是调用本方法来获取结果的
  72. *
  73. ***/
  74. function getdatalink()
  75. {
  76. if ( $this->numitems )
  77. {
  78. global $db;
  79. $pageid = $this->currentpageid;
  80. $from = ($pageid - 1)*$this->pagesize;
  81. $count = $this->pagesize;
  82. $link = $db->limitquery($this->sql, $from, $count); //使用pear db::limitquery方法保证数据库兼容性
  83. return $link;
  84. }
  85. else
  86. {
  87. return false;
  88. }
  89. }
  90. /***
  91. *
  92. * 以二维数组的格式返回结果集
  93. *
  94. ***/
  95. function getpagedata()
  96. {
  97. if ( $this->numitems )
  98. {
  99. if ( $res = $this->getdatalink() )
  100. {
  101. if ( $res->numrows() )
  102. {
  103. while ( $row = $res->fetchrow() )
  104. {
  105. $result[] = $row;
  106. }
  107. }
  108. else
  109. {
  110. $result = array();
  111. }
  112. return $result;
  113. }
  114. else
  115. {
  116. return false;
  117. }
  118. }
  119. else
  120. {
  121. return false;
  122. }
  123. }
  124. function _setoptions($option)
  125. {
  126. $allow_options = array(
  127. 'pagesize',
  128. 'currentpageid',
  129. 'sql',
  130. 'numitems'
  131. );
  132. foreach ( $option as $key => $value )
  133. {
  134. if ( in_array($key, $allow_options) && ($value != null) )
  135. {
  136. $this->$key = $value;
  137. }
  138. }
  139. return true;
  140. }
  141. }
  142. ?>

分页代码调用:

  1. // filename: test_pager.php
  2. // 这是一段简单的示例代码,前边省略了使用pear db类建立数据库连接的代码
  3. require "pager.class.php";
  4. if ( isset($_get['page']) )
  5. {
  6. $page = (int)$_get['page'];
  7. }
  8. else
  9. {
  10. $page = 1;
  11. }
  12. $sql = "select * from table order by id";
  13. $pager_option = array(
  14. "sql" => $sql,
  15. "pagesize" => 10,
  16. "currentpageid" => $page
  17. );
  18. if ( isset($_get['numitems']) )
  19. {
  20. $pager_option['numitems'] = (int)$_get['numitems'];
  21. }
  22. $pager = @new pager($pager_option);
  23. $data = $pager->getpagedata();
  24. if ( $pager->isfirstpage )
  25. {
  26. $turnover = "首页|上一页|";
  27. }
  28. else
  29. {
  30. $turnover = "numitems."'>首页|previouspageid."&numitems=".$pager->numitems."'>上一页|";
  31. }
  32. if ( $pager->islastpage )
  33. {
  34. $turnover .= "下一页|尾页";
  35. }
  36. else
  37. {
  38. $turnover .= "nextpageid."&numitems=".$pager->numitems."'>下一页|numpages."&numitems=".$pager->numitems."'>尾页";
  39. }
  40. ?>

说明: 这个类仅仅处理数据,并不负责处理显示,因为将数据的处理和结果的显示都放到一个类里边实在是有些勉强。 显示时情况和要求多变,不如自己根据类给出的结果处理,更好的方法是根据这个pager类继承一个自己的子类来显示不同的分页,比如显示用户分页列表可以:

  1. class memberpager extends pager
  2. {
  3. function showmemberlist()
  4. {
  5. global $db;
  6. $data = $this->getpagedata();
  7. // 显示结果的代码
  8. // ......
  9. }
  10. }
  11. /// 调用
  12. if ( isset($_get['page']) )
  13. {
  14. $page = (int)$_get['page'];
  15. }
  16. else
  17. {
  18. $page = 1;
  19. }
  20. $sql = "select * from members order by id";
  21. $pager_option = array(
  22. "sql" => $sql,
  23. "pagesize" => 10,
  24. "currentpageid" => $page
  25. );
  26. if ( isset($_get['numitems']) )
  27. {
  28. $pager_option['numitems'] = (int)$_get['numitems'];
  29. }
  30. $pager = @new memberpager($pager_option);
  31. $pager->showmemberlist();
  32. ?>

第二,不同数据库的兼容性,在不同的数据库里截获一段结果的写法是不一样的。

  1. $pagenum=@ceil($num/$pagesize);
  2. if($num > $pagesize){
  3. if($pageval<=1) $pageval=1;
  4. if($pageval==$pagenum){
  5. echo "首页 上一页 下一页 末页";
  6. //echo "第".$pageval."页/共".$pagenum."页";
  7. echo " 到第 页,共 $pagenum 页";
  8. }
  9. }
  10. }
  11. ?>

人气教程排行