mongdb 聚合 分组查询,java写和nosql

nosql写法

db.gm_qlxx.aggregate([
    { $match : {ctime : {$gte:new Date(2018,11,7), $lte:new Date(2020,11,7) } ,flowcode:{$nin:[null]}} },
    { $group : {_id:{netFlowdefCode:"$netFlowdefCode",djjg:"$djjg"}, num_total:{$sum:1} }},
     {$sort:{"_id":1}}
    ]); 
    

java写法

List<String> strings=new ArrayList<>();
Criteria criteria = Criteria.where("ctime").gte(startDate).lte(endDate).and("flowcode").nin(strings);
Aggregation aggregation = Aggregation.newAggregation(
        Aggregation.match(criteria),
        Aggregation.group(Aggregation.fields("netFlowdefCode","djjg")).count().as("numTotal")
);
AggregationResults<Map> results = mongoTemplate.aggregate(aggregation,"gm_qlxx",Map.class);
        //转换对象好操作
return  MapToObject.parse(results.getMappedResults(),AggResult.class);

集合list<map> 转换list<Object> ,转对象为了方便取值

package com.greatmap.internet.estate.utils;

import org.apache.commons.beanutils.ConvertUtils;
import org.apache.commons.beanutils.PropertyUtils;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

/**
 * @author lxw
 * @date 2020/11/26 17:30
 */
public class MapToObject {

    /**
     * 此方法实现JDBCTemplate
     * 返回的Map集合对数据的自动
     * 封装功能
     * List集合存储着一系列的MAP
     * 对象,obj为一个javaBean
     * @return
     */
    public static List parse(List list, Class obj){
        //生成集合
        ArrayList ary = new ArrayList();
        //遍历集合中的所有数据
        for(int i = 0; i<list.size(); i++){
            try {
                生成对象实历 将MAP中的所有参数封装到对象中
                Object o = addProperty( (Map)list.get(i),obj.newInstance() );
                //把对象加入到集合中
                ary.add(o);
            } catch (InstantiationException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } catch (IllegalAccessException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        //返回封装好的集合
        return ary;
    }

    /**Map对象中的值为 name=aaa,value=bbb
     调用方法
     addProperty(map,user);
     *将自动将map中的值赋给user类
     *此方法结合Spring框架的jdbcTemplete将非
     *常有用
     * @return封装好的对象
     */
    public static Object addProperty(Map map, Object obj){
        //遍历所有名称
        Iterator it = map.keySet().iterator();
        while(it.hasNext()){
            //取得名称
            String name = it.next().toString();
            //取得值
            String value = map.get(name).toString();
            try{
                //取得值的类形
                Class type = PropertyUtils.getPropertyType(obj, name);
                if(type!=null){
                    //设置参数
                    PropertyUtils.setProperty(obj, name, ConvertUtils.convert(value, type));
                }
            }catch(Exception ex){
                ex.printStackTrace();
            }
        }
        return obj;

    }


}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,MongoDB是一个流行的NoSQL数据库,用于存储和处理大量非结构化数据。MongoDB提供了强大的聚合框架,也称为聚合管道,用于对文档进行复杂的查询、过滤、分组和计算操作。聚合统计是MongoDB聚合框架的核心功能,它允许你在不直接修改基础数据集的情况下,生成新的报告或者提取所需的信息。 Java MongoDB聚合统计通常涉及以下几个步骤: 1. **$match**:用于选择文档,只保留满足特定条件的文档进入聚合过程。 2. **$group**:将文档按照某些字段进行分组,并计算每个组的聚合值,如计数、求和、平均等。 3. **$project**:重新定义输出文档的结构,可以添加、删除或修改字段。 4. **$sort**:对结果进行排序。 5. **$limit**:限制返回的文档数量。 6. **$unwind**:如果文档中的某个字段是数组,可以展开成多个文档。 7. **$lookup**:执行跨集合的连接操作,用于获取其他集合的数据。 例如,一个简单的Java代码片段可能会这样使用Aggregation pipeline: ```java MongoCollection<Document> collection = mongoDatabase.getCollection("yourCollection"); Bson matchFilter = Filters.eq("field", "value"); Aggregation_pipeline pipeline = Arrays.asList( Aggregation.match(matchFilter), Aggregation.group("$field", new Document("$sum", "$amount")), Aggregation.project("_id", "$field", "$sum"), Aggregation.sort(Sorts.ascending("_id")) ); List<Document> result = collection.aggregate(pipeline).into(new ArrayList<>()); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值