sql >> Databasteknik >  >> NoSQL >> MongoDB

Fråga en array av arrayer i MongoDB

Intressant fråga, det här kommer att göra susen

 db.multiArr.find({'Keys':{$elemMatch:{$elemMatch:{$in:['carrot']}}}})

$elemMatch används för att kontrollera om ett element i en array matchar den angivna matchningen expression.so kapslade $elemMatch kommer att gå djupare in i kapslade arrayer

Testdata   

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" ] ] }


  1. hur läser man alla bytes som kommer på en tcp-anslutning?

  2. phpRedis-migrering till kluster och konsekvent hashning

  3. 9 ClusterControl-funktioner som du inte hittar i andra databashanteringsverktyg

  4. bästa praxis för django + PyMongo pooling?