需求:对表数据进行分组后,根据某个字段去重,然后在count
命令行有 db.collection.distinct("someField")
问:用morphia应该怎么写?或者通过原生的mongodb驱动应该怎么做?
如果用聚合的话,怎么才能当查询的结果为null时统计的数量为0,比如sql中的 isNull(count(1), 0)
Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
调用
com.mongodb.DBCollection#distinct方法,对应问题中的命令行db.collection.distinct("someField")。这样会把所有的数据都返回,所以如果只是为了得到count,没必要用distinct。
可以直接用aggregate。