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