我有我的想法是蒙戈一个非常简单的,简单的查询,并创建了索引:为什么我的索引只能在Mongo Query中使用?
{ "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
]
]
}
}
任何明显的想法我做错了什么?谢谢!
如果你更换' “结束” 发生了:{ “$ NE”:真正}'和' “结束”:FALSE'? (或不在你的模式中工作?) – Rich