Büyük bir koleksiyon (300k + kayıtları) depolamak için MongoDB 1.6.3 kullanıyorum. Bir bileşik endeks ekledim. AncakMongoDB - index hatası olmadan sort() için çok fazla veri
db['collection_name'].getIndexes()
[
{
"name" : "_id_",
"ns" : "db_name.event_logs",
"key" : {
"_id" : 1
}
},
{
"key" : {
"updated_at.t" : -1,
"community_id" : 1
},
"ns" : "db_name.event_logs",
"background" : true,
"name" : "updated_at.t_-1_community_id_1"
}
]
, ben bu kodu çalıştırmayı deneyin: alıyorum
db['collection_name']
.find({:community_id => 1})
.sort(['updated_at.t', -1])
.skip(@skip)
.limit(@limit)
:
Mongo :: OperationFailure (çok fazla veri sıralama için () hiçbir indeksi Bir dizinini ekleyin veya daha küçük bir sınır belirtin)
Neyi yanlış yapıyorum?
Sıralama sütunu, dizinin son sütunu olmalıdır. http://www.mongodb.org/display/DOCS/Indexing+Advice+and+FAQ#IndexingAdviceandFAQ-1.Thesortcolumnmustbethelastcolumnusedintheindex. –