Entfernen von "scanAndOrder": true in meinem MongoDB-Abfrageergebnis
Ich habe also eine Sammlung in meiner Datenbank mit dem folgenden Shardkey: {cl: "yyyy-mm", user_id: N}
wenn ich die folgende Abfrage durchführe
db.collection.find({ cl:"2012-03", user_id:{$in:users}, _id:{"$lt":new ObjectId('4f788b54204cfa4946000044')} }).sort({_id:-1}).limit(5).explain(true)
es gibt mir dieses Ergebnis:
"clusteredType" : "ParallelSort",
"shards" : {
"set1/hostname.com:27018" : [
{
"cursor" : "BtreeCursor cl_1_user_id_1 multi",
"nscanned" : 21294,
"nscannedObjects" : 21288,
"n" : 5,
"scanAndOrder" : true,
"millis" : 1258,
"nYields" : 69,
"nChunkSkips" : 0,
"isMultiKey" : false,
"indexOnly" : false,
"indexBounds" : { ...
Also, wie kann ich die Sortierung vornehmen, um den Index zu verwenden, dann muss ich nicht alle 21288 Dokumente scannen, nur um die letzten 5 zurückzugeben?