phalcon分页的处理
由于项目是用phalcon做的,主要是处理api,也做些简单的web页面。
有一个页面是显示日志的,结果后来日志达到几万条后php内存爆了,查了一下代码,
居然是直接读出所有数据库数据,使用的\Phalcon\Paginator\Adapter\NativeArray来做分页的,被雷到了。
但是我又不想改动view,查看了一下Paginator的属性,于是简单写了十多行,一切ok了。
function pageNew($pageNum,$pageSum,$items) { $page = new \stdClass(); $page->items=$items; $page->current=$pageNum; $page->before=$pageNum-1; $page->next=$pageNum+1; $page->last=$pageSum; $page->total_pages = $pageSum; $this->view->page = $page; }
在查询的地方修改
$currentPage = $this->request->getQuery('page', 'int'); if(empty($currentPage) || $currentPage < 1) { $currentPage = 1; } $limit = " LIMIT ". ($currentPage-1)*self::PAGE_LIMIT . "," . self::PAGE_LIMIT;
则每次查询后把结果传给pageNew函数即可,遗憾的每次翻页时都要做一次count,不过考虑到次数在查询时会变化,而且也不会浏览全部,还是可以接受的。
作者:半山
出处:http://www.cnblogs.com/xdao/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。