php – 使用Propel统计和分组

在Doctrine中,我可以做到:
public function getCount() 
{        
        $q = $this->createquery('q')
            ->select('*')
            ->addSelect('count(q.name) as count')
            ->groupBy('q.name')
            ->orderBy('count DESC');

        return $q->execute();        
}

如何在Symfony 1.4中的Propel中做同样的事情?

该死的!它比那更容易!

如果需要计算给定查询的结果行,则需要使用count()终止方法,基本上:

MyTableQuery::create()->count();

有关更多信息,请阅读以下文档部分:http://www.propelorm.org/documentation/03-basic-crud.html#query_termination_methods

如果要在查询添加count或nb extra列,表示COUNT或SUM等sql聚合函数,则应使用withColumn()方法

$query = MyTableQuery::create()
    ->withColumn('COUNT(*)','Count')
    ->select(array('Name','Count'))
    ->groupByName()
    ->orderByCount()
    ;

$results = $query->find();

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...