我们在Node.JS中有以下查询
@H_502_2@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(例如).所以最后一个总是在底部.
我们如何再次实现这一目标?
解决方法
您需要使用聚合框架.
@H_502_2@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);
});
});