douliang1891 2016-05-12 14:55
浏览 117
已采纳

Yii2 MongoDB明显不计

How to get count distinct values from the collection using query? Now I am using this solution:

$collection = Yii::$app->mongodb->getCollection('collection_name');
$result = $collection->distinct('field_id');
return count($result);

Collection example:

    {
       {a: 2},
       {a: 2},
       {b: 3},
       {c: 4}    
    }

Result must be:

3
  • 写回答

2条回答 默认 最新

  • duankaolei2921 2016-05-12 15:14
    关注

    You can use the aggregation framework for this:

    $collection = Yii::$app->mongodb->getCollection('collection_name');
    $result = $collection->aggregate(
        array('$group' => array(
            '_id' => '$field_id'
        )),
        array('$group' => array(
            '_id' => 1,
            'count' => array( '$sum' => 1 )
        ))
    );
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥15 DruidDataSource一直closing
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据