我找不到任何地方有这样的记录。默认情况下,find()操作将从头获取记录。我怎么能得到mongodb的最后N条记录?
编辑:我也想返回的结果从最近到最近的顺序,而不是相反。
我找不到任何地方有这样的记录。默认情况下,find()操作将从头获取记录。我怎么能得到mongodb的最后N条记录?
编辑:我也想返回的结果从最近到最近的顺序,而不是相反。
当前回答
db.collection.find().hint( { $natural : -1 } ).sort(field: 1/-1).limit(n)
根据mongoDB文档:
您可以指定{$natural: 1}强制查询执行转发集合扫描。 您还可以指定{$natural: -1}来强制查询执行反向收集扫描。
其他回答
使用.sort()和.limit()
按升序或降序使用Sort,然后使用limit
db.collection.find({}).sort({ any_field: -1 }).limit(last_n_records);
最后添加的N条记录,从最近的到最近的,可以用这个查询看到:
db.collection.find().skip(db.collection.count() - N)
如果你想把它们的顺序颠倒:
db.collection.find().sort({ $natural: -1 }).limit(N)
如果你安装了Mongo-Hacker,你还可以使用:
db.collection.find().reverse().limit(N)
如果你厌倦了一直写这些命令,你可以在你的~/.mongorc.js中创建自定义函数。如。
function last(N) {
return db.collection.find().skip(db.collection.count() - N);
}
然后在mongo shell中输入last(N)
根据集合的大小,排序、跳过等操作可能会非常慢。
如果您根据某些标准对集合进行索引,则可以获得更好的性能;然后你可以使用min()游标:
首先,使用db.collectionName索引集合。setIndex(yourIndex) 你可以使用升序或降序,这很酷,因为你总是想要“最后N项”……所以如果你按降序索引,就相当于得到“前N项”。
然后你找到你的集合的第一项,并使用它的索引字段值作为搜索的最小条件,如下所示:
db.collectionName.find().min(minCriteria).hint(yourIndex).limit(N)
下面是min()游标的引用:https://docs.mongodb.com/manual/reference/method/cursor.min/
使用$slice操作符限制数组元素
GeoLocation.find({},{name: 1, geolocation:{$slice: -5}})
.then((result) => {
res.json(result);
})
.catch((err) => {
res.status(500).json({ success: false, msg: `Something went wrong. ${err}` });
});
其中geolocation是数据数组,从中我们得到最近5条记录。
如果你使用MongoDB compass,你可以使用sort field来过滤,