我是mongodb和mongoose的新手,我很难获得子数组。
我的数据是这样的:
[
{_id : ...,
name : 'Category name1',
products : [
{
code : 'zxcv'
name : 'T-Shirt 1',
items : [
{code:'zxcv', size : 'S'}
{code:'zxcv', size : 'M'}
{code:'zxcv', size : 'L'}
{code:'zxcv', size : 'XL'}
]
},
{
code : 'qwerty'
name : 'T-Shirt 2',
items : [
{code:'qwerty', size : 'S'}
{code:'qwerty', size : 'M'}
{code:'qwerty', size : 'L'}
{code:'qwerty', size : 'XL'}
]
}
]
},
{_id : ...,
name : 'Category name2',
products : [ ... ]
}
]
我只想获取代码='zxcv'的产品
如果我做:
ProductGroup.find({'products.code' : 'zxcv'},function(err, products){})
我得到了所有第一类产品-不仅仅是代码='zxcv'的产品
最佳答案
我想到了。由于我花了数小时来寻找答案,但找不到答案,因此这可能会帮助另一个遇到相同问题的菜鸟:
要获得匹配的产品:
ProductGroup.find({'products.code' : 'zxcv'},'products.code.$.items', function(err, products){})
关于mongodb - 仅获取与MongooseJs中的查询匹配的子子数组,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/22201167/