java - mongodb框架morphia中怎么去重?
高洛峰
高洛峰 2017-04-17 15:15:00
[Java讨论组]

需求:对表数据进行分组后,根据某个字段去重,然后在count

命令行有 db.collection.distinct("someField")

问:用morphia应该怎么写?或者通过原生的mongodb驱动应该怎么做?

如果用聚合的话,怎么才能当查询的结果为null时统计的数量为0,比如sql中的 isNull(count(1), 0)

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(1)
ringa_lee

调用com.mongodb.DBCollection#distinct方法,对应问题中的命令行 db.collection.distinct("someField")
这样会把所有的数据都返回,所以如果只是为了得到count,没必要用distinct。
可以直接用aggregate。

db.collection.aggregate(
    [{
        $group:{
            _id:"$someField",
            count:{$sum:1}
        }
    }]
)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号