dpdjpt5137 2015-09-24 17:38
浏览 72
已采纳

zf2 paginator count total

How can one retrieve the total number of items found with count() via the Zend Pagintor, NOT the page count? Current tests come up with this approximation as the closest without manipulating the DBSelect count method:

$totalCount = $pagintor->count() * $paginator->getItemCountPerPage();

My question relates to the count() process used by the paginator to get the total number of records.

I've seen this: Zend Framework 2 - Pagination and read these docs http://framework.zend.com/manual/current/en/modules/zend.paginator.advanced.html

http://framework.zend.com/manual/current/en/modules/zend.paginator.usage.html

Are we to customise the count() method for the pagination object just to get the count as per last link?

class MyDbSelect extends Zend\Paginator\Adapter\DbSelect
{
    public function count()
    {
        $select = new Zend\Db\Sql\Select();
        $select->from('item_counts')->columns(array('c'=>'post_count'));

        $statement = $this->sql->prepareStatementForSqlObject($select);
        $result    = $statement->execute();
        $row       = $result->current();
        $this->rowCount = $row['c'];

        return $this->rowCount;
    }
}

$adapter = new MyDbSelect($query, $adapter);
$paginator = new Zend\Paginator\Paginator($adapter);

Maybe I've missed something (probably true...) but since the pagination object has already gone to the trouble of compiling a 'count' why/how can we access this number without doing any other hurdles or obstacle courses... Is there a $paginator->getTotalCount() method somewhere to access this variable...

The final result might be something like '20 records of 4536 total' where 4536 the total.

Many thanks in advance.

ENV: ZF 2.3.9 (not 2.4+)

展开全部

  • 写回答

1条回答 默认 最新

  • dongse7261 2015-09-24 23:25
    关注

    Sounds like you want totalItemCount.

    $paginator->getTotalItemCount();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部