Подтвердить что ты не робот

Запрос массива массивов в MongoDB

Скажем, у меня есть такой документ.

"ID" : "fruit1",
"Keys" : [["apple", "carrot", "banana]]

Как запросить для Keys = "морковь". Ни один из следующих синтаксисов не работает.

db.myColl.results.find({ "Keys" : "carrot" });
db.myColl.results.find({ "Keys" : [["carrot"]] });

После работы, но не полезно.

db.myColl.results.find({ "Keys" : [["apple", "carrot", "banana]]});

Любой указатель на этот запрос будет полезен. Спасибо.

4b9b3361

Ответ 1

Интересный вопрос. Это будет трюк

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

Ответ 2

если вы хотите найти массив данных первой позиции, используйте 0 в качестве ссылочного индекса для получения данных во вложенном массиве.

db.getCollection('routes').find({"routeId" : 12,'routes._id':ObjectId("598da27a713f3e6acd72287f"),'routes.0.stops.0.orders.0._id':ObjectId("598da27a713f3e6acd722887")})