只获得与MongooseJs中的查询匹配的子子数组

时间:2014-03-05 14:51:45

标签: mongodb

我是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'的产品

1 个答案:

答案 0 :(得分:5)

我明白了。由于我花了几个小时寻找答案而找不到答案,也许这会帮助另一个有相同问题的菜鸟:

获得匹配的产品:

ProductGroup.find({'products.code' : 'zxcv'},'products.code.$.items', function(err, products){})