今天是:
设为首页 加入收藏
  首页  文章  下载  小说  幽默  IT  QQ家园  小店  FLASH  汽车  
您现在的位置: 星雨小站 >> 文章 >> 电脑技术 >> 网页制作 >> 数据库 >> SQL >> 文章正文 用户登录 新用户注册
MySQL分页模型(Pagination.php)         
MySQL分页模型(Pagination.php)
作者:佚名 文章来源:不详 点击数: 更新时间:2005-8-23 11:12:43


*/

class Pagination {
        var $pageSize;        //页大小
        var $pageNo;                //当前页码
        var $rowCount;        //记录总数
        var $pageCount;        //总页数
        var $records;                //当前页记录
        var $currentPageSize;        //当前页记录总数
        var $currentPageStartNo;     //当前页开始记录号

        //判断是否有下一页
        function hasNextPage() {
                return $this->pageNo < $this->pageCount;
        }
        //取得下一页页码
        function getNextPageNo() {
                return $this->pageNo + 1;
        }

        //判断是否有上一页
        function hasPriorPage() {
                return $this->pageNo > 1;
        }
        //取得上一页页码
        function getPriorPageNo() {
                return $this->pageNo - 1;
        }

        //判断是否第一页
        function isFirstPage(){
                return $this->pageNo == 1 || $this->pageCount==0;
        }

        //判断是否最后一页
        function isLastPage(){
                return $this->pageNo == $this->pageCount || $this->pageCount==0;
        }

        //装载某一页数据,成功则返回true,失败则返回false
        //        dataMaker是一个函数名,用于将一条记录转换为一个对象
        //        有一个参数为当前记录所有字段的值(一个以数字或字段名为索引的数组)
        function load($con, $sql, $dataMaker, $pageSize, $pageNo){
                //页大小和当前页码必须>=1
                if( $pageSize<1 || $pageNo<1 ) return false;

                //查询
                if( $rst = @mysql_query($sql, $con) ){
                        $this->pageSize = $pageSize;
                        $this->pageNo = $pageNo;

                        $this->rowCount = @mysql_num_rows($rst);
                        $this->pageCount = (int)(($this->rowCount + $this->pageSize - 1) / $this->pageSize);
                        $this->records = array();

                        //将光标移动到指定页的第一条记录前
                        $this->currentPageStartNo = ($this->pageNo - 1) * $this->pageSize + 1;
                        $firstRowNo = $this->currentPageStartNo;
                        while( --$firstRowNo>0 && @mysql_fetch_array($rst) );

                        //取出指定页的数据
                        $read = 0;
                        $this->currentPageSize = 0;
                        while( $read<$this->pageSize && $row=@mysql_fetch_array($rst) ){
                                $this->records[$this->currentPageSize++] = $dataMaker($row);
                                $read++;
                        }
                }
                else{
                        return false;
                }

                return true;
        }
};
?>


中搜索与
的相似内容
立刻搜索→

文章录入:小雨    责任编辑:小雨 
  • 上一篇文章:

  • 下一篇文章: 没有了
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口



    推荐文章[组图]无损硬盘数据调整…
    普通文章上线[问好,打招呼] QQ表…
    普通文章拜拜[再见,晚安,下线] …
    普通文章钱[钞票,大款] QQ表情
    普通文章[组图]应知应会的5个图…
    普通文章跟我学用“记事本”
    普通文章用好Windows自带的录音…
    普通文章来测试你的网速-比比看…
    推荐文章文件夹加密过程中因误操…
    推荐文章[组图]无损硬盘数据调整…
    推荐文章能够安装多个杀毒软件吗…
    推荐文章爱情专用系列 QQ表情
    推荐文章用画图工具给图片添加文…
    推荐文章老公增加零花钱的请示报…
    推荐文章QQ搞笑表情(二) QQ表情
    推荐文章悠嘻猴 QQ表情
    修改Tomcat的主配置文…
    ORACLE常见错误代码的…
    学习oracle sql loade…
    oracle数据库运算:in…
    ORACLE联机日志文件丢…
    Oracle sqlplus语句编…
    使用Delphi6的DBExpre…
    用perl访问mysql数据库
    用javabean来实现MySQ…
    什么是项目管理器,数…
    见识一下面向对象的编…
    FOXPRO 对象、属性、事…
    FOXPRO 常用的对象、属…
    FOXPRO常用编程命令及…
    在Oracle 9i isqlplus…

    糯米猪系列 QQ表情

    愚人节qq表情 QQ表情

    花脸猫系列 QQ表情

    uc表情系列 QQ表情
    (只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    版权所有 Copyright© 2004-2005 星空联盟工作室 EMAIL:xingyu@xyu01.com
    给我发消息 给我发消息

    本站Alaxa全球网站排名 (点击查看)(安装Alexa工具条,查看各大网站全球排名)