简易 PHP+MySQL 分页类

原创 2012年09月13日 07:32:27

初学者一般都不太理解分页的原理,因此常常为分页发愁

paging.php

<?php
class Paging {
  public static $count = 0;
  public static $size = 0;
  public static $page = 0;
  static function prepare($sql, $pagesize=10) {
    $page = isset($_GET['page']) ? $_GET['page'] : 1;
    $pageon = ($page - 1) * $pagesize;
    $sql = preg_replace('/select\s/i', '$0SQL_CALC_FOUND_ROWS ', $sql) . " limit $pageon, $pagesize";
    $rs = mysql_query($sql);
    $p = mysql_query('SELECT FOUND_ROWS()');
    list(self::$count) = mysql_fetch_row($p);
    self::$size = $pagesize;
    self::$page = $page;
    return $rs;
  }
  static function bar($tpl='') {
    if(!$tpl) $tpl = '<a href=?reset>首页</a> <a href=?prve>上一页</a> <a href=?next>下一页</a> <a href=?end>尾页</a>';
    $count = ceil(self::$count / self::$size);
    $page = self::$page;
    unset($_GET['page']);
    $d = array(
      'reset' => 1,
      'prve' => $page > 1 ? $page - 1 : 1,
      'next' => $page < $count ? $page + 1 : $count,
      'end' => $count,
    );
    foreach($d as $k=>$v) {
      $_GET['page'] = $v;
      $tpl = str_replace($k, http_build_query($_GET), $tpl);
    }
    echo $tpl;
  }
}

通常你都有类似这样的语句
$sql =".....";
$rs = mysql_query($sql);

$rs = mysql_query("select ....");


你只需改作
include 'paging.php';
$rs = paging::prepare($sql, 每页行数);
在需要出现分页条的地方写入
paging::bar();

就可以了,非常简单!


换一种调用写法,可能感觉要好些

paging.php

class Paging {
  private static $_Instance;
  private function __clone(){}
  public static function getInstance() {
    if(empty(self::$_Instance)) self::$_Instance = new self();
    return self::$_Instance;
  }

  protected $count = 0;
  protected $size = 0;
  protected $page = 0;
  function prepare($sql, $pagesize=10) {
    $page = isset($_GET['page']) ? $_GET['page'] : 1;
    $pageon = ($page - 1) * $pagesize;
    $sql = preg_replace('/select\s/i', '$0SQL_CALC_FOUND_ROWS ', $sql) . " limit $pageon, $pagesize";
    $rs = mysql_query($sql);
    $p = mysql_query('SELECT FOUND_ROWS()');
    list($this->count) = mysql_fetch_row($p);
    $this->size = $pagesize;
    $this->page = $page;
    return $rs;
  }
  function bar($tpl='') {
    if(!$tpl) $tpl = '共{count}页 第{page}页 <a href=?{reset}>首页</a> <a href=?{prve}>上一页</a> <a href=?{next}>下一页</a> <a href=?{end}>尾页</a>';
    $count = ceil($this->count / $this->size);
    $page = $this->page;
    $d = array(
      '{reset}' => 1,
      '{prve}' => $page > 1 ? $page - 1 : 1,
      '{next}' => $page < $count ? $page + 1 : $count,
      '{end}' => $count,
      '{count}' => $count,
      '{page}' => $page,
    );
    foreach($d as $k=>&$v) {
      if(in_array($k, array('{reset}', '{prve}', '{next}', '{end}'))) {
        $_GET['page'] = $v;
        $v = http_build_query($_GET);
      }
    }
    echo strtr($tpl, $d);
  }
}
function mysql_paging_query($sql, $num=10) {
  return Paging::getInstance()->prepare($sql, $num);
}
function mysql_paging_bar($tpl='') {
  return Paging::getInstance()->bar($tpl);
}

include 'paging.php';
$rs = mysql_paging_query($sql, 20);//替代 mysql_query
mysql_paging_bar();//显示分页条


php+mysql分页类

拿去改改就能很好用的php+mysql分页类: 本程序文件对分页程序进行了封装
  • u011986449
  • u011986449
  • 2014年04月08日 21:00
  • 1632

php+mysql 最简单的留言板

学完了记得动手操作。
  • think_ycx
  • think_ycx
  • 2015年08月13日 01:07
  • 1952

PHP+MySql 分页原理

所谓分页显示,也就是讲数据库中的结果集,一段一段显示出来 关键知识点: SQL语句中的limit用法: SELECT * FROM table …… limit   开始位置 , 操作条数  ...
  • theArcticOcean
  • theArcticOcean
  • 2016年02月16日 10:09
  • 479

利用php和mysql实现小型聊天室

利用php和mysql实现小型聊天室。   数据库的配置:   online表:(表示人员是否在线)     logs表(表示人员进出情况)      reguser表(表示人员注册情况) mes...
  • hxy19971101
  • hxy19971101
  • 2016年10月13日 17:48
  • 2546

jquery 简易分页

实现效果需要引入的文件 index.html
  • Admin_yi
  • Admin_yi
  • 2017年04月20日 13:19
  • 529

PHP+MYSQL分页原理

1、SQL语句中的limit用法 2、学习分页的一种公式 3、parse_url()解析URL函数 parse_url() 是将URL解析成有固定键值的数组的函数...
  • tianfeng1208
  • tianfeng1208
  • 2013年08月02日 23:13
  • 638

基于php+mysql实现分页技术

基于php+mysql实现分页技术 1.全部代码          PHP+MySQL实现分页技术          body{         font-size:12px;...
  • mico_cmm
  • mico_cmm
  • 2016年10月30日 19:11
  • 147

PHP+MySQL 分页那点事

分页技术随处可见,这可以算得上是最为基础的网站功能了。于是今天尝试着用PHP来实现一个分页的小例子。 准备工作 环境准备 Apache MySQL PHP 工作环境 数据库准备 建库 建表 预存数据 ...
  • Marksinoberg
  • Marksinoberg
  • 2016年08月13日 19:12
  • 6509

php+mysql实现分页

第一步:连接数据库 conn.php文件 $link=mysqli_connect("localhost","数据库用户名","数据库密码","数据库名"); if(!$link){ die('c...
  • miss_zxm
  • miss_zxm
  • 2017年07月05日 16:52
  • 83

PHP+MySQL分页原理实现

学习日期:20150630 整个功能的实现主要分为三个步骤: 1.传入页码; 2.根据页码取出数据,php->mysql操作; 3.显示数据、分页条。 关键点 在于: 实现定量取指的SQL...
  • anonywoas
  • anonywoas
  • 2015年07月01日 10:12
  • 113
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:简易 PHP+MySQL 分页类
举报原因:
原因补充:

(最多只允许输入30个字)