gpt4 book ai didi

带有总和的 mongodb 聚合 addToSet

转载 作者:可可西里 更新时间:2023-11-01 09:27:56 25 4
gpt4 key购买 nike

我找不到这方面的任何例子,所以我不确定这是否可行。我有以下文件

db.mytest.insert([
{ date: new Date('2013-06-01'),
account: 'A',
ids: [ { id: '1vb', sale: 50 }, { id: 'xy2', sales: 25 } ]
},
{ date: new Date('2013-06-02'),
account: 'A',
ids: [ { id: '1vb', sales: 10 }, { id: 'xy2', sales: 5 } ]
}
])

我正在尝试获得以下结果

[{ account: 'A': 
ids: [ { id: '1vb', salesAmount: 60, salesCount: 8 },
{ id: 'xy2', salesAmount: 30, salesCount: 3 }
]
}]

我尝试了以下管道

var unwind = { $unwind: '$ids' };
var group = { $group: {
_id: { id: '$ids.id' },
ids: { $addToSet:
{
salesAmount: { $sum: '$ids.salesAmount' },
salesCount: { $sum: '$ids.salesCount' }
}
}
}};

db.mytest.aggregate([unwind, group])

但是它返回了这个错误

Error: Printing Stack Trace
at printStackTrace (src/mongo/shell/utils.js:37:7)
at DBCollection.aggregate (src/mongo/shell/collection.js:897:1)
at (shell):1:11
Sun Jul 7 18:53:26.177 JavaScript execution failed: aggregate failed: {
"errmsg" : "exception: invalid operator '$sum'",
"code" : 15999,
"ok" : 0
} at src/mongo/shell/collection.js:L898

最佳答案

我让它与这条管道一起工作。

var unwind = { "$unwind" : "$ids" };
var group = {
"$group" : {
"_id" : {
"account" : "$account",
"id" : "$ids.id"
},
"idSalesAmount" : {
"$sum" : "$ids.salesAmount"
},
"idSalesCount" : {
"$sum" : "$ids.salesCount"
}
}};
var group2 = {
"$group" : {
"_id" : "$_id.account",
"ids" : {
"$addToSet" : {
"id" : "$_id.id",
"salesAmount" : "$idSalesAmount",
"saleCount" : "$idSalesCount"
}
}
}};
var project = { "$project" : { "account" : "$_id", "ids" : 1, "_id" : 0 } };

db.mytest.aggregate([unwind, group, group2, project])

关于带有总和的 mongodb 聚合 addToSet,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17517205/

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