我最近提出这个问题,帮助我获取一个数组,用于在聚合mongoDB查询中获取结果(MongoDB Aggregate Array with Two Fields)
我现在的问题是获得两个不同的组合键。
我有一个包含一般产品的产品系列:
{
"_id" : ObjectId("554b9f223d77c810e8915539"),
"brand" : "Airtex",
"product" : "E7113M",
"type" : "Fuel Pump",
"warehouse_sku" : [
"1_5551536f3d77c870fc388a04",
"2_55515e163d77c870fc38b00a"
]
}
我有以下儿童产品(它上面有多种一般产品)
{
"_id" : ObjectId("55524d0c3d77c8ba9cb2d9fd"),
"brand" : "Performance",
"product" : "P41K",
"type" : "Fuel Pump Component",
"general_products" : [
ObjectId("554b9f123d77c810e891552f"),
ObjectId("554b9f143d77c810e8915530"),
ObjectId("554b9f173d77c810e8915533"),
ObjectId("554b99b83d77c810e8915436"),
ObjectId("554b9f2e3d77c810e8915549")
],
"warehouse_sku" : [
"1_555411043d77c8066b3b6720",
"1_555411073d77c8066b3b6728"
]
}
我的问题是我希望带有_id和内部子产品的一般产品与特定的warehouse_sku模式匹配。期望的结果是这样的:
{ "_id" : ObjectId("554b9f2e3d77c810e8915549") }
{ "_id" : ObjectId("554b99b83d77c810e8915436") }
{ "_id" : ObjectId("554b9f173d77c810e8915533") }
{ "_id" : ObjectId("554b9f143d77c810e8915530") }
{ "_id" : ObjectId("554b9f123d77c810e891552f") }
{ "_id" : ObjectId("554b9f223d77c810e8915539") }
我做了多个查询,如:
1)
db.products.aggregate([
... {$match:{warehouse_sku: /^1/ }},
... {$unwind:"$general_products"},
... {$group:{_id: "$general_products"}}
... ])
但是来自一般产品的_id不在其上:
{ "_id" : ObjectId("554b9f2e3d77c810e8915549") }
{ "_id" : ObjectId("554b99b83d77c810e8915436") }
{ "_id" : ObjectId("554b9f173d77c810e8915533") }
{ "_id" : ObjectId("554b9f143d77c810e8915530") }
{ "_id" : ObjectId("554b9f123d77c810e891552f") }
2)
db.products.aggregate([
... {$match:{warehouse_sku: /^1/ }},
... {$group:{_id: "$_id"}}
... ])
但请给我一般和儿童产品[不要它]的_id,但不要给儿童产品中的一般产品_id:
{ "_id" : ObjectId("55524d0c3d77c8ba9cb2d9fd") }
{ "_id" : ObjectId("554b9f223d77c810e8915539") }
答案 0 :(得分:1)
使用以下聚合管道获取所需的ObjectId列表。如果数组_id
字段不存在,则使用$ifNull
聚合运算符添加general_products
字段:
db.products.aggregate([
{
"$match": {"warehouse_sku": /^1/ }
},
{
"$group": {
"_id": {
"_id": "$_id",
"general_products": "$general_products"
},
"data": {
"$addToSet": "$_id"
}
}
},
{
"$project": {
"_id": 0,
"general_products": {
"$ifNull": ["$_id.general_products", "$data"]
}
}
},
{
"$unwind": "$general_products"
},
{
"$group": {
"_id": null,
"list_products": {
"$addToSet": "$general_products"
}
}
}
]);
这将为您提供一个带有ObjectIds数组list_products
的文档:
/* 1 */
{
"result" : [
{
"_id" : null,
"list_products" : [
ObjectId("554b9f223d77c810e8915539"),
ObjectId("554b9f2e3d77c810e8915549"),
ObjectId("554b99b83d77c810e8915436"),
ObjectId("554b9f173d77c810e8915533"),
ObjectId("554b9f143d77c810e8915530"),
ObjectId("554b9f123d77c810e891552f")
]
}
],
"ok" : 1
}