MongoDB 的 cursor 到底是怎么工作的?
首先使用以下代码初始化 collection
db.collection.drop() for (i = 0; i < 100; i++) { db.collection.insertOne({x: Math.floor(i/5)}); }
然后执行var cursor = db.collection.find().batchSize(5).sort({x: 1})获取到 cursor,执行cursor.next()5 次,在执行第六次之前,执行db.collection.insertOne({x: 0}),这时执行cursor.next()的结果为{x: 1}。
我的疑问
为什么cursor.next()的结果不是{x: 0}呢? cursor 到底是怎么工作的?它是怎么决定下次 batch 应该取哪些数据的呢?
相关资料
- What is a Cursor in MongoDB? – Stack Overflow