Java整合MongoDB分组查询

Java整合MongoDB分组查询

在网上看了很久的资料,最后在这个帖子里实现了功能,比起其他的帖子通俗易懂

链接:https://blog.csdn.net/qq_41012810/article/details/97260673

下面是我修改后的代码:

在这里插入图片描述
只需要指定要分组的字段,由于我是要取所有数据进行分组,就将所有条件都删除了,就留了个获取分组数量的条件
在这里插入图片描述

代码贴一下

private List<Map<String, Object>> getTypeCountAndData(){
        List<Map<String, Object>> list = new ArrayList<>();
        Map<String, Object> map = null;

        String[] field = {"typeId","type"}; 		//分组的依据,根据那些参数进行分组
        Aggregation aggregation1 = Aggregation.newAggregation(
                Aggregation.group(field).count().as("count")	//分组中的数量    ,as 起别名
        );
        //执行
        AggregationResults<BasicDBObject> outputTypeCount1 = template.aggregate(aggregation1, "alarm", BasicDBObject.class);
        //迭代器进行迭代
        for (Iterator<BasicDBObject> iterator = outputTypeCount1.iterator(); iterator.hasNext(); ) {
            map = new HashMap<>();
            DBObject obj = iterator.next();
            // 拿出自己所需要的值
            String type = obj.get("type").toString();
            String count = obj.get("count").toString();
            String typeId = obj.get("typeId").toString();
            map.put("type", type);
            map.put("count", count);
            map.put("typeId", typeId);
            list.add(map);
        }

        return list;
    }

又是有收获的一天

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值