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

Как массивы индексов MongoDB?

В MongoDB, если бы я должен был хранить массив (скажем ["red", "blue"]) в поле "color", он индексирует "red" и "blue", чтобы я мог запросить для "red", например, или в make {"red", "blue"} составной индекс?

4b9b3361

Ответ 1

Когда дело доходит до индексирующих массивов, MongoDB индексирует каждое значение массива, поэтому вы можете запрашивать отдельные элементы, такие как "красный". Например:

> db.col1.save({'colors': ['red','blue']})
> db.col1.ensureIndex({'colors':1})

> db.col1.find({'colors': 'red'})
{ "_id" : ObjectId("4ccc78f97cf9bdc2a2e54ee9"), "colors" : [ "red", "blue" ] }
> db.col1.find({'colors': 'blue'})
{ "_id" : ObjectId("4ccc78f97cf9bdc2a2e54ee9"), "colors" : [ "red", "blue" ] }

Для получения дополнительной информации ознакомьтесь с документацией MongoDB на Multikeys: http://www.mongodb.org/display/DOCS/Multikeys