码迷,mamicode.com
首页 > 数据库 > 详细

【MongoDB】嵌套数组查询方案

时间:2015-04-16 11:51:42      阅读:325      评论:0      收藏:0      [点我收藏+]

标签:

From:http://stackoverflow.com/questions/12629692/querying-an-array-of-arrays-in-mongodb

数据

db.multiArr.insert({"ID" : "fruit1","Keys" : [["apple", "carrot", "banana"]]})
db.multiArr.insert({"ID" : "fruit2","Keys" : [["apple", "orange", "banana"]]})


db.multiArr.find({‘Keys‘:{$elemMatch:{$elemMatch:{$in:[‘carrot‘]}}}})
{ "_id" : ObjectId("506555212aeb79b5f7374cbf"), "ID" : "fruit1", "Keys" : [ [ "apple", "carrot", "banana" ] ] }

db.multiArr.find({‘Keys‘:{$elemMatch:{$elemMatch:{$in:[‘banana‘]}}}})

{ "_id" : ObjectId("506555212aeb79b5f7374cbf"), "ID" : "fruit1", "Keys" : [ [ "apple", "carrot", "banana" ] ] }
{ "_id" : ObjectId("5065587e2aeb79b5f7374cc0"), "ID" : "fruit2", "Keys" : [ [ "apple", "orange", "banana" ] ] }

查询语句:

Interesting question, This will do the trick

db.multiArr.find({‘Keys‘:{$elemMatch:{$elemMatch:{$in:[‘carrot‘]}}}})
$elemMatch used to check if an element in an array matches the specified match expression. so nested $elemMatch will go deeper into nested arrays

【MongoDB】嵌套数组查询方案

标签:

原文地址:http://www.cnblogs.com/colipso/p/4431343.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!