zoukankan      html  css  js  c++  java
  • Yii 分页方法总结

    在 Controller中如下代码:

    public function actionIndex()    
        {    
            $criteria = new CDbCriteria();    
            $criteria->order = 'createtime desc';        
            $count = Article::model()->count($criteria);    
                
            $pager = new CPagination($count);    
            $pager->pageSize = 10;             
            $pager->applyLimit($criteria);    
        
            $artList = Article::model()->findAll($criteria);    
            $this->render('index',array('pages'=>$pager,'list'=>$artList));    
        }  
    

     在视图中代码如下:

    <div id="pager">    
        <?php    
        
        $this->widget('CLinkPager',array(    
            'header'=>'',    
            'firstPageLabel' => '首页',    
            'lastPageLabel' => '末页',    
            'prevPageLabel' => '上一页',    
            'nextPageLabel' => '下一页',    
            'pages' => $pages,    
            'maxButtonCount'=>13    
            )    
        );    
        ?>    
        </div> 
    

     一般写法:

    $criteria = new CDbCriteria;    
    $count = DnOnline::model()->count($criteria);    
        
    $pages = new CPagination($count);                   
    $pages->pageSize = 5;    
    $pages->applylimit($criteria);    
        
    $model = DnOnline::model()->findAll($criteria); 
    

     CDB写法:

    $criteria = new CDbCriteria;    
        $sql = "SELECT * FROM USER";    
        $model= Yii::app()->db->createCommand($sql)->queryAll();    
        $pages = new CPagination(count($model));                   
        $pages->pageSize = 4;    
        $pages->applylimit($criteria);    
        
        $model=Yii::app()->db->createCommand($sql." LIMIT :offset,:limit");    
        $model->bindValue(':offset', $pages->currentPage*$pages->pageSize);    
        $model->bindValue(':limit', $pages->pageSize);    
        $model=$model->queryAll();   
    
        $criteria=new CDbCriteria();    
                    $result = Yii::app()->db->createCommand($sql_do)->query();    
                   $pages=new CPagination($result->rowCount);    
                  $pages->pageSize=2;    
                    $pages->applyLimit($criteria);    
                  $result=Yii::app()->db->createCommand($sql_do." LIMIT 2");    
                   $result->bindValue(':offset', $pages->currentPage*$pages->pageSize);    
                 $result->bindValue(':limit', $pages->pageSize);    
                 $list=$result->query();   
    
  • 相关阅读:
    处处留心皆学问,世事如棋局局新…
    【转载】2017 软件测试行业现状调查报告_From_51testing_On_20180625
    Hello World In Go ...
    C# 易错题整理
    C# 函数
    C# 哈希表,队列,栈
    C# 数组,集合,泛型集合
    C# 如何生成验证码
    C# 年月日时间题+Timespan
    闰年的一个BUG
  • 原文地址:https://www.cnblogs.com/moleng/p/2958038.html
Copyright © 2011-2022 走看看