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