2016-08-15 77 views
0

我正在使用Mongoose的聚合(MongoDB v3.2)。数据库中有两个项目factory1factory2。每个工厂都有一个字段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选择?因为后来我想再次获得完整的项目。由于

回答

2

更改$match使用$elemMatch,要求这两个词由同一个products元素满足:

Factory.aggregate([ 
    { $match: { products: { $elemMatch: { 
    code1: 'aa', 
    code2: 'BB' 
    }}}} 
]); 
+0

哇,谢谢,工作完美!我只知道$ elemMatch也可以用于聚合,不仅在查询中! –