我是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/

10-12 22:33