在yii中使用分页

      yii中使用分页很方便,如下两种方法:

      在控制器中:

      1、

1
2
3
4
5
6
7
$criteria = new CDbCriteria();     //new cdbcriteria数据库<br>$criteria->id = 'id ASC';           //排序规则
$count = Exchange::model()->count($criteria);
$pager = new CPagination($count);
$pager->pageSize=30;
$pager->applyLimit($criteria);
         
$categoryInfo = Category::model()->findAll($criteria); //根据条件查询

  2、

1
2
3
4
5
6
7
8
9
$criteria = new CDbCriteria();
$criteria->order = 'id ASC';
$criteria->addCondition('status=1');      //根据条件查询
$criteria->addCondition('exchange_status=0');
$count = Exchange::model()->count($criteria);
$pager = new CPagination($count);
$pager->pageSize=30;
$pager->applyLimit($criteria); 
$exchangeInfo = Exchange::model()->findAll($criteria);

 render中传入参数:

   array("pages" => $pager)

 视图中加入:

 

1
2
3
4
5
6
7
8
9
10
$this->widget('CLinkPager',array(
               'header'=>'',
               'firstPageLabel' => '首页',
               'lastPageLabel' => '末页',
               'prevPageLabel' => '上一页',
               'nextPageLabel' => '下一页',
               'pages' => $pages,
               'maxButtonCount'=>8,
         )
         );

  分页思想: 1、计算数据库中总的条数

                    2、分页大小

                    3、设置偏移量limit

    在Yii中,分页时会用这个类CDBcritria进行数据库查询很重要,这样分页很简单。

posted @   xshang  阅读(13957)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 单线程的Redis速度为什么快?
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示