我正在通過傳遞這些資料來創建一些報告:
Reports Model
userId : String,
marketId : String,
marketName : String,
itemId : String,
minPricePerKg : Number,
maxPricePerKg : Number
按POST要求創建 3 個報告:
POST /reports
request 1:
{
"details": {
"userId": "1",
"marketId": "1",
"marketName": "market1",
"itemId": "1",
"minPricePerKg": "10",
"maxPricePerKg": "20",
}
}
request 2:
{
"details": {
"userId": "2",
"marketId": "1",
"marketName": "market1",
"itemId": "1",
"minPricePerKg": "20",
"maxPricePerKg": "40",
}
}
request 3:
{
"details": {
"userId": "1",
"marketId": "2",
"marketName": "market2",
"itemId": "1",
"minPricePerKg": "80",
"maxPricePerKg": "100",
}
}
我想獲得某個特定itemId(從查詢中收到)的所有報告的平均價格。因此,為了便于理解,我們將使用itemId..過濾掉所有報告$match : { itemId }
請求時
GET /reports?itemId=1
Expected Output
[
{
"marketId": "1",
"itemId": "1",
"marketName": "market1",
"users": ["1", "2"],
"minPrice": 15,
"maxPrice": 30
},
{
"marketId": "2",
"itemId": "1",
"marketName": "market2",
"users": ["1"],
"minPrice": 80,
"maxPrice": 100
}
]
這里minPrice是平均所有的minPricePerKg和maxPrice是平均所有的maxPricePerKg有各自的marketId's報告。我也想獲得所有欄位 ie( marketId, marketName, users, itemId) 結果
我得到的輸出是:
[
{
"_id": {
"marketId": "market1"
},
"minPrice": 15,
"maxPrice": 30
},
{
"_id": {
"marketId": "market2"
},
"minPrice": 80,
"maxPrice": 100
}
]
我的方法是這樣的:
const res = await Report.aggregate([
{ $match: { itemId } },
{ $group: { _id: { marketId : "$marketId" }, minPrice: { $avg: '$minPricePerKg' }, maxPrice: { $avg: '$maxPricePerKg' } } },
{ $project: { "marketName": 1 } },
]);
uj5u.com熱心網友回復:
詢問
- group 保留組中常見的那些欄位
- 并積累這些都不是常見的
users和MinPriceMaxPrice
測驗代碼在這里
aggregate(
[{"$replaceRoot": {"newRoot": "$details"}},
{"$group":
{"_id":
{"marketId": "$marketId",
"itemId": "$itemId",
"marketName": "$marketName"},
"avgMinPrice": {"$avg": {"$toDouble": "$minPricePerKg"}},
"avgMaxPrice": {"$avg": {"$toDouble": "$maxPricePerKg"}},
"users": {"$push": "$userId"}}},
{"$replaceRoot": {"newRoot": {"$mergeObjects": ["$_id", "$$ROOT"]}}},
{"$project": {"_id": 0}}])
轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/387318.html
