【发布时间】:2018-07-14 02:48:10
【问题描述】:
我有以下数据:
{
"make" : "Toyota",
"name" : "Corolla",
"year" : "2012"
"color" : "Blue"
}
{
"make" : "Toyota",
"name" : "Camry",
"year" : "2016"
"color" : "Blue"
}
{
"make" : "Toyota",
"name" : "Prius",
"year" : "2012"
"color" : "Black"
}
{
"make" : "Nissan",
"name" : "PathFinder",
"year" : 2012.0
"color" : "Black"
}
{
"make" : "Nissan",
"name" : "Qashqai",
"year" : 2011.0
"color" : "Black"
}
{
"make" : "Nissan",
"name" : "X-Trail",
"year" : 2009.0
"color" : "Blue"
}
我想编写一个聚合查询来按make 分组,然后在make 组中按color 分组。
所以我想要的结果的摘录看起来像这样
[{
_id: "Toyota"
colors: [
{
_id: "Black"
cars: [{
"make" : "Toyota",
"name" : "Prius",
"year" : "2012"
"color" : "Black"
}]
},
{
_id: "Blue"
cars:[{
"make" : "Toyota",
"name" : "Corolla",
"year" : "2012"
"color" : "Blue"
},
{
"make" : "Toyota",
"name" : "Camry",
"year" : "2016"
"color" : "Blue"
}]
}
]
},
{
.... Nissan cars
}]
我已经尝试了以下管道并且已经有点接近我想要的结果,但它并不理想
db.Cars.aggregate(
// Pipeline
[
// Stage 1
{
$group: {
_id: {make: '$make', color: '$color'},
cars: {$push: '$$CURRENT'}
}
},
// Stage 2
{
$group: {
_id: '$_id.make',
colors: {$push: '$$CURRENT'}
}
},
]
);
这会导致(注意颜色的 _id 字段):
[{
"_id" : "Toyota",
"colors" : [
{
"_id" : {
"make" : "Toyota",
"color" : "Black"
},
"cars" : [
{
"make" : "Toyota",
"name" : "Prius",
"year" : "2012",
"color" : "Black"
}
]
},
{
"_id" : {
"make" : "Toyota",
"color" : "Blue"
},
"cars" : [
{
"make" : "Toyota",
"name" : "Corolla",
"year" : "2012",
"color" : "Blue"
},
{
"make" : "Toyota",
"name" : "Camry",
"year" : "2016",
"color" : "Blue"
}
]
}
]
}
...
]
任何关于编写查询以使输出更接近所需结果的帮助都会很好
【问题讨论】:
标签: mongodb