JAVA Aggreation实现金额汇总

1.统计一个内嵌集合里面的金额总计:sum(mioLogList.amnt)

Aggregation sumJeAgg = Aggregation.newAggregation(

Aggregation.match(Criteria.where("applNo").is("4140427596704768").and("isInValid").is("1")),//条件
Aggregation.unwind("mioLogList"), //将子集合拆分成开
Aggregation.group("sum").sum("mioLogList.amnt").as("sumAmnt") // 分组
);
AggregationResults<Object> aggRes = mongoTemplate.aggregate(sumJeAgg, "需要查询的文档",Object.class);

BasicDBList jeBas =(BasicDBList) aggRes.getRawResults().get("result");

BasicDBObject jeDb=(BasicDBObject) jeBas.get(0);
System.out.println(jeDb.get("sumAmnt"));


今天碰到问题,当我:

,写个日志记录下,以免以后继续犯错,知道当加上project后,就不能在group里面自定义key 原因的同学,可以分享下原因吗?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
假设有一个包含多个订单的订单列表,每个订单包含订单号、商品名称和商品金额等字段,现在需要根据订单号将订单列表中的金额进行汇总。可以使用Java中的Stream API和Collectors类来实现这个功能。代码如下: ```java import java.math.BigDecimal; import java.util.*; import java.util.stream.Collectors; public class OrderDemo { public static void main(String[] args) { List<Order> orderList = new ArrayList<>(); orderList.add(new Order("001", "商品A", new BigDecimal("100.00"))); orderList.add(new Order("002", "商品B", new BigDecimal("200.00"))); orderList.add(new Order("001", "商品C", new BigDecimal("300.00"))); orderList.add(new Order("003", "商品D", new BigDecimal("400.00"))); Map<String, BigDecimal> result = orderList.stream() .collect(Collectors.groupingBy(Order::getOrderNo, Collectors.mapping(Order::getAmount, Collectors.reducing(BigDecimal.ZERO, BigDecimal::add)))); System.out.println(result); } } class Order { private String orderNo; private String productName; private BigDecimal amount; public Order(String orderNo, String productName, BigDecimal amount) { this.orderNo = orderNo; this.productName = productName; this.amount = amount; } public String getOrderNo() { return orderNo; } public void setOrderNo(String orderNo) { this.orderNo = orderNo; } public String getProductName() { return productName; } public void setProductName(String productName) { this.productName = productName; } public BigDecimal getAmount() { return amount; } public void setAmount(BigDecimal amount) { this.amount = amount; } } ``` 输出结果为: ``` {001=400.00, 002=200.00, 003=400.00} ``` 其中,`groupingBy`方法根据订单号进行分组,然后使用`mapping`方法将每个订单的金额映射为BigDecimal类型的值,最后使用`reducing`方法对每个组内的金额进行累加,得到每个订单号对应的总金额

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值