我们在Node.JS中有以下查询
mongo.connect('mongodb://XXX:XXX@ds054XXX.mlab.com:54289/XXXdb',function (err,db) { var collection = db.collection('chatmessages') var stream = collection.find().sort({ _id: -1 }).limit(20).stream(); stream.on('data',function (chat) { socket.emit('user message',chat.content,chat.dateCreated); }); });
如您所见,查询是输入的最后20条记录的集合.但是从这个结果我们想再次使用_id中的1,所以在列表中我们将使用ID 55 – 75(例如).所以最后一个总是在底部.
我们如何再次实现这一目标?
解决方法
您需要使用聚合框架.
mongo.connect('mongodb://XXX:XXX@ds054XXX.mlab.com:54289/XXXdb',db) { var collection = db.collection('chatmessages') var stream = collection.aggregate([ { "$sort": { "_id": -1}},{ "$limit": 20 },{ "$sort": { "_id": 1 }} ]); stream.on('data',chat.dateCreated); }); });