0
我正在使用Mongoose的聚合(MongoDB v3.2)。数据库中有两个项目factory1
和factory2
。每个工厂都有一个字段products
,它是一个数组。
我要选择具有产品code1=='aa'
& code2=='BB'
// factory1.products
[{
code1: 'aa',
code2: 'AA'
}, {
code1: 'bb',
code2: 'BB'
}]
// factory2.products
[{
code1: 'aa'
code2: 'BB'
}]
这是我现在该怎么办所有的工厂:
Factory
.aggregate([
{ $unwind: '$products' }, // Ensure get factory2 only when use $match. Without $unwind, will get both factory1 and factory2
{ $match: {
'products.code1': 'aa',
'products.code2': 'BB'
}}
]);
有没有办法不使用$unwind
选择?因为后来我想再次获得完整的项目。由于
哇,谢谢,工作完美!我只知道$ elemMatch也可以用于聚合,不仅在查询中! –