gpt4 book ai didi

java - 如何将 AggregateIterable 值保存到 mongodB 中的 map ?

转载 作者:行者123 更新时间:2023-12-01 19:07:46 28 4
gpt4 key购买 nike

我是 MongoDB 新手。经过大量搜索后,我应用了如下聚合操作,并且它按预期工作:

AggregateIterable<Document> summary= collection.aggregate(
Arrays.asList(
Aggregates.match(Filters.eq("financialEventType", "REFUND")),
Aggregates.group("_id",
Accumulators.sum("revenueHeader_Principal","$revenueHeader.Principal"),
Accumulators.sum("revenueHeader_ProductTax","$revenueHeader.Product Tax"),
Accumulators.sum("revenueHeader_Shipping","$revenueHeader.Shipping"),
Accumulators.sum("revenueHeader_ShippingTax","$revenueHeader.Shipping Tax"),
Accumulators.sum("revenueHeader_GiftWrap","$revenueHeader.Gift Wrap"),
Accumulators.sum("revenueHeader_GiftWrapTax","$revenueHeader.Gift Wrap Tax"),)
));

LinkedHashMap<String, BigDecimal> revenueSummary = new LinkedHashMap<String, BigDecimal>();

现在我想按特定顺序将这些值保存在 RevenueSummary 中。但是如何迭代摘要或通过名称访问项目?

最佳答案

您可以使用 while 语句进行迭代。
注意:如果结果超过 1 个,您将保存最后文档值。

MongoCursor<Document> iterator = summary.iterator();
while (iterator.hasNext()) {
Document next = iterator.next();

//Copy from Document key-value
revenueSummary.put("Principal", (BigDecimal) next.get("revenueHeader_Principal"));
revenueSummary.put("ProductTax", (BigDecimal) next.get("revenueHeader_ProductTax"));
//...
}

链接: https://www.programcreek.com/java-api-examples/index.php?api=com.mongodb.client.AggregateIterable

关于java - 如何将 AggregateIterable<Document> 值保存到 mongodB 中的 map ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59517472/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com