MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Запитване на масив от масиви в MongoDB

Интересен въпрос, това ще свърши работа

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

$elemMatch използва се за проверка дали даден елемент в масива съвпада с посочения израз за съвпадение. така вложен $elemMatch ще навлезе по-дълбоко във вложените масиви

Тестови данни   

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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB или CouchDB - годни за производство?

  2. Попълнете липсващите дати в записите

  3. Брой в хранилището на Spring Data MongoDB

  4. Начини за внедряване на версии на данни в MongoDB

  5. „Статични“ методи на Mongoose срещу „инстанционни“ методи