У меня есть документ по странам, который выглядит так:
{
"_id" : ObjectId("4e493af4140700590800154f"),
"geoname_id" : "49518",
"code" : "rw",
"names" : {
"en" : "Rwanda",
"nl" : "Rwanda",
"de" : "Ruanda"
}
}
Чтобы коснуться индекса только при запросе:
db.countries.find({}, {"names.en":1, _id:0})
Я добавил следующий индекс:
db.countries.ensureIndex({"names.en":1})
Насколько я понимаю, запрос теперь должен касаться только индекса.
Однако .explain () говорит мне, что запрос вообще не использует какой-либо индекс:
{
"cursor" : "BasicCursor",
"nscanned" : 247,
"nscannedObjects" : 247,
"n" : 247,
"millis" : 0,
"nYields" : 0,
"nChunkSkips" : 0,
"isMultiKey" : false,
"indexOnly" : false,
"indexBounds" : {
}
}
Я думал, что причина может заключаться в том, что будет выведен полный дБ (247 стран)
но это не имеет никакого смысла для меня. Когда страны доступны в индексе
индекс должен быть использован, верно?
У кого-нибудь есть идея?
Приветствия