【赵强老师】在MongoDB中使用游标

先看视频。

【赵强老师】在MongoDB中使用游标

MongoDB有一个很重要的特性就是游标Cursor。db.collection.find()方法将返回一个游标。如果要访问文档,我们需要使用游标的迭代器。但是,在mongo shell中,如果没有给返回的游标指定变量,游标将自动首先返回前20条记录。
关闭游标:默认情况下,10分钟内没有使用使用的游标会被自动关闭。可以使用.noCursorTimeout()来设置游标的关闭选项,这时就需要手动关闭游标。例如:var mycursor = db.emp.find().noCursorTimeout()

游标使用注意事项

  • 游标执行过程中,修改数据可能会影响游标返回的结果

    由于Mongo存储数据的问题,当执行修改文档时,文档由于大小的变化则修改后不一定会放到原来的位置。这也是Mongo在执行一段时间后需要整理空间碎片的原因。当然文档位置发生了变化之后(放到了其他的位置),游标在创建完之后就像是一个快照,当游标获取下一次的数据的时候,则不能全部获取所有的数据。这个时候需要使用快照(snapshot)进行查询,则会查询默认索引_id的数据,但是性能会比较差。如下:var cursor = db.user.find({}).snapshot();

  • 游标的生命周期

    游标需要知道客户端和服务端都在做什么,最重要的是服务端需要维护创建的游标,当游标创建的过多,或者没有及时的进行释放,可能会增加服务器的资源压力。

发布了64 篇原创文章 · 获赞 0 · 访问量 4476

猜你喜欢

转载自blog.csdn.net/zhaoyuqiang/article/details/105160264