我找不到任何地方有这样的记录。默认情况下,find()操作将从头获取记录。我怎么能得到mongodb的最后N条记录?

编辑:我也想返回的结果从最近到最近的顺序,而不是相反。


当前回答

你可以试试这个方法:

获取集合中记录的总数

db.dbcollection.count() 

然后使用skip:

db.dbcollection.find().skip(db.dbcollection.count() - 1).pretty()

其他回答

使用.sort()和.limit()

按升序或降序使用Sort,然后使用limit

db.collection.find({}).sort({ any_field: -1 }).limit(last_n_records);

如果你使用MongoDB compass,你可以使用sort field来过滤,

查看查询:排序和自然顺序,http://www.mongodb.org/display/DOCS/Sorting+and+Natural+Order 以及游标方法下的sort() http://www.mongodb.org/display/DOCS/Advanced+Queries

如果我理解了你的问题,你需要按升序排序。

假设你有一些id或日期字段称为“x”,你会做…

.sort ()


db.foo.find().sort({x:1});

1将升序排序(从最老到最新),而-1将降序排序(从最新到最老)。

如果你使用自动创建的_id字段,它有一个日期嵌入其中…所以你可以用它来订购…

db.foo.find().sort({_id:1});

这将返回从最老到最新排序的所有文档。

自然秩序


你也可以使用上面提到的自然顺序……

db.foo.find().sort({$natural:1});

同样,使用1或-1取决于你想要的顺序。

使用.limit ()


最后,在执行这种广泛开放的查询时添加一个限制是一个很好的实践,这样你就可以这样做…

db.foo.find().sort({_id:1}).limit(50);

or

db.foo.find().sort({$natural:1}).limit(50);
 db.collection.find().sort({$natural: -1 }).limit(5)