暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

MongoDB 中游标(Cursor)

MongoDB学习园 2018-08-29
2139





引入

db.collection.find()方法返回一个游标结果,访问文档需要遍历这个游标值。 在mongo shell 中返回的游标值没有赋值给 var 关键字定义的变量时会自动遍历20次并打印这头20条的文档结果,如果返回的游标值赋值给了var 关键字定义的变量时不会自动遍历这个游标结果。

Tips:这里的游标返回默认结果数20可以通过 DBQuery.shellBatchSize 来修改。



手动(遍历)迭代游标

  • 运行游标结果,迭代(遍历)并打印20条匹配到的文档:

  • 使用游标的 next()方法访问文档:

  • 打印结果当然也可以使用 printjson() 来替换 print(tojson()):

  • 也可以使用游标的 forEach() 迭代(遍历)游标来访问文档:


迭代索引

在mongo shell 中可以使用游标的 toArray() 方法迭代遍历游标结果,并将结果集放在一个数组中返回。

toArray() 方法会将游标中的所有文档加载到内存中,同时耗尽这个游标。


有部分Mongodb数据库驱动提供根据cursor索引位置获取文档数据的方法。(例如:cursor[index]). 这是先调用toArray()方法再用索引获取数组中元素的简写。


游标行为

  • 关闭不活动的Cursor

默认情况下,服务器会自动关闭超过10分钟活跃的或客户端已耗尽的游标。想不使用这个默认行为在 mongo shell 中可以使用ursor.noCursorTimeout()方法:

设定noCursorTimeout这个选项后,你必须通过cursor.close()方法手动关闭, 或者耗尽这个游标。


  • 游标隔离

当游标返回文档时,其他操作可能与查询交织。对于MMAPv1存储引擎,如果文档发生更改,对文档的写入操作可能导致游标多次返回文档。若要处理此情况,请参阅游标快照信息。


  • 游标批处理

MongoDB服务器将结果打包返回. 数据包的大小不能超过默认BOSN文档大小(16M)maximum BSON document size。 可以通过batchSize()和limit()来修改返回结果集。

3.4 新版本 find(), aggregate(), listIndexes, 和listCollections每批返回最大16M的数据。batchSize()可以设置一个更小的限制, 而不是最大的限制。

find()和aggregate() 默认初始集合文档数量是101。后来的getMore操作,没有默认集合文档数量限制, 只是有16M最大字节数限制。


Tips:有sort排序没有索引的查询操作时, 返回结果前, 服务器必须将全部数据加载进内存中来实现排序。


遍历结果集到达返回数据的末尾时, 如果有更多的数据, cursor.next()方法会执行getMore operation操作来得到下一批数据。可以通过objsLeftInBatch()方法来查看在当前数据还有多少数据没有遍历.


游标信息

db.serverStatus()方法返回一个包括了metrics字段的文档。metrics字段的metrics.cursor有以下信息:

  • 自服务器器启动以来超时游标数;

  • 使用DBQuery.Option.noTimeout 选项防止超时打开的游标数;

  • pinned 打开的游标数量;

  • 打开游标的总数量;

db.serverStatus().metrics.cursor

结果显示

译自: https://docs.mongodb.com/manual/tutorial/iterate-a-cursor/

游标方法参考: https://docs.mongodb.com/manual/reference/method/#js-query-cursor-methods

最后修改时间:2019-12-24 11:24:46
文章转载自MongoDB学习园,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论