У меня есть, как мне показалось, довольно простой, простой запрос в Mongo, и я создал индекс:
{ "Ended" : 1, "EndDate" -1 }
Однако, когда я выполняю простой запрос к нему, он, кажется, распознает индекс, но он все еще сканирует МНОГО объектов, чтобы извлечь данные. Вот мой запрос и объясните результаты:
PRIMARY> db.listing.find({ "Ended" : { "$ne" : true }, "EndDate" : { "$lte" : ISODate("2011-11-18T00:47:40.638Z") } }).explain();
{
"cursor" : "BtreeCursor Ended_1_EndDate_-1 multi",
"nscanned" : 24508585,
"nscannedObjects" : 24508583,
"n" : 24508583,
"millis" : 108323,
"nYields" : 0,
"nChunkSkips" : 0,
"isMultiKey" : false,
"indexOnly" : false,
"indexBounds" : {
"Ended" : [
[
{
"$minElement" : 1
},
true
],
[
true,
{
"$maxElement" : 1
}
]
],
"EndDate" : [
[
ISODate("2011-11-18T00:47:40.638Z"),
true
]
]
}
}
Есть какие-нибудь очевидные идеи, что я делаю не так? Спасибо!