我是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'的产品
答案 0 :(得分:5)
我明白了。由于我花了几个小时寻找答案而找不到答案,也许这会帮助另一个有相同问题的菜鸟:
获得匹配的产品:
ProductGroup.find({'products.code' : 'zxcv'},'products.code.$.items', function(err, products){})