位置: 编程技术 - 正文

MongoDB中游标的深入学习(mongodb游记)

编辑:rootadmin

推荐整理分享MongoDB中游标的深入学习(mongodb游记),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mongodb有表的概念吗,mongodb游记,mongodb有表的概念吗,mongotemplate游标查询,mongotemplate游标查询,mongodb 游标,mongodb的表,mongotemplate游标查询,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

MongoDB中的游标与关系型数据库中的游标在功能上大同小异。游标相当于C语言的指针,可以定位到某条记录,在MongoDB中,则是文档。因此在mongoDB中游标也有定义,声明, 打开,读取,关闭这么个过程。客户端通过游标,能够实现对最终结果进行有效的控制,诸如限制结果数量,跳过部分结果或根据任意键按任意顺序的组合对结果进行各种排序等。

通俗的说,游标不是查询结果,可以理解为数据在遍历过程中的内部指针,其返回的是一个资源,或者说数据读取接口.

客户端通过对游标进行一些设置就能对查询结果进行有效地控制,如可以限制查询得到的结果数量、跳过部分结果、或对结果集按任意键进行排序等!

直接对一个集合调用find()方法时,我们会发现,如果查询结果超过二十条,只会返回二十条的结果,这是因为Mongodb会自动递归find() 返回的游标。

下文是针对MongoDB游标的具体介绍。

一、mongoDB游标介绍

db.collection.find()方法返回一个游标,对于文档的访问,我们需要进行游标迭代

mongoDB的游标与关系型数据库SQL中的游标类似,可以通过对游标进行(如限制查询结果数,跳过的结果数等)设置来控制查询结果

游标会消耗内存和相关系统资源,游标使用完后应尽快释放资源

在mongo shell中,如果返回的游标结果集未指定给某个var定义的变量,则,游标自动迭代次,即输出前个文档,超出的情形则需要输入it来翻页

本文内容描述手动方式来实现游标迭代来访问文档或者是用索引迭代

声明游标

var cursor = db.collectioName.find(query,projection);

打开游标

Cursor.hasNext() 判断游标是否已经取到尽头

读取数据

Cursor.Next() 取出游标的下一个文档

关闭游标

cursor.close() 此步骤可省略,通常为自动关闭,也可以显示关闭

MongoDB中游标的深入学习(mongodb游记)

用while循环来遍历游标示例

游标生命周期

a、游标完成匹配结果的迭代后,它会清除自身;

b、客户端的游标已经不在作用域内,驱动程序回向服务器发送一条特别的消息,让其销毁;

c、缺省情况下,游标在十分钟内没有使用,游标自动关闭或者客户端已经迭代完整个游标;

d、可以通过cursor.noCursorTimeout()来定义游标超时时间

如:var myCursor = db.users.find().noCursorTimeout()

e、对于自定义超时时长的游标可以使用cursor.close() 来关闭游标

如:db.collection.find(<query>).close()

二、当前环境及数据准备

二、使用print输出游标结果集

三、使用printjsont输出游标结果集

四、使用 forEach()进行迭代

五、基于数组索引迭代

可以使用toArray()将游标迭代文档返回到一个数组,然后通过数组下标方式进行访问。 该方法将所有由游标返回的文档装载进内存。

六、调整游标迭代次数

七、查看游标度量信息

可以通过db.serverStatus()查看游标状态相关的信息,这些信息通常包括

从服务器上次启动之后游标超时的数量

自定义游标超时的数量

游标打开后已经pinned的数量

打开游标的总数目

总结

标签: mongodb游记

本文链接地址:https://www.jiuchutong.com/biancheng/312602.html 转载请保留说明!

上一篇:CentOS 7下用yum快速安装MongoDB的方法教程(centos7自带yum吗)

下一篇:mongoDB 实现主从读写分离实现的实例代码(mongodb中主键的默认格式是哪个?)

  • 一般纳税人收到普票如何入账
  • 税收成本包括哪些
  • 利润10万企业所得税多少
  • 购买财务软件如何做凭证
  • 应付账款暂估余额
  • 收到固定资产发票抵扣进项税
  • 代发工资记什么科目
  • 微信小程序实现微信支付
  • 未交增值税怎么记账
  • 农产品收购发票图片
  • 卖房土地增值税税率
  • 小规模企业核定征收最新政策
  • 私车公用税务处理办法
  • 工程项目的业务流程
  • ca浏览器组件如何下载?
  • 低于成本价销售的税务风险
  • 金融机构同业利息收入增值税税率
  • 增值税暂行条例属于
  • 淘宝店铺毛利率多少是正常
  • 专票有电子发票有抵扣联吗
  • 网速保护功能介绍
  • 开具信息咨询费的发票
  • Linux怎么使用vi
  • kb4507449安装失败
  • bigfile是什么意思
  • 在php中,字符串有哪些表示形式
  • 现金折扣的会计处理方法
  • 固定资产清理如何结转
  • 收不回的应收账款会计分录
  • php不刷新提交
  • 财务报销单据不能用圆珠笔写吗
  • 解决掉发的有效方法
  • vue中的$el
  • 个税系统怎么查询已申报个人明细
  • look 查明
  • 卖家运费险是不是退货免费
  • 帝国cms怎么用
  • 苗木免税只能开普票
  • 医用口罩的适用人群
  • mysql连接数据库的基本步骤是什么
  • 专项附加扣除哪种申报方式好
  • sqlserver时间格式化时分秒
  • 投资性房地产进项税抵扣
  • 在windowsxp的应用程序中,经常
  • 社保缴费基数和医保缴费基数一样吗
  • 车船税每年都是一样的吗
  • 上市公司回购股票多久可出售
  • 商场联营方案
  • 建筑施工企业在12个月内第三次发生生产安全事故的
  • 母子公司无偿划转土地
  • 一般纳税人车辆租赁费的税率是多少
  • 出口不退税进项要转出吗
  • 快递公司的主营业务范围
  • 航天开票系统怎么导出已开票明细
  • 企业所得税必须预缴吗
  • 什么是盈亏平衡法
  • sql怎么比较两个表字段的内容
  • Vista系统提高ADSL上网速度的两种设置方法
  • linux系统中的用户分为哪几类
  • qbdagent2002.exe - qbdagent2002是什么进程 有什么用
  • mac系统怎么创建用户
  • centos8设置默认启动命令界面
  • 开发环境配置是干嘛
  • excel f9刷新
  • node.js怎么用
  • vue前端后端
  • jquery源码分析笔记
  • JavaScript获取元素
  • python os模块
  • 简单的横向棱纹魔杖
  • context和getApplicationContext()介绍
  • 完美世界打斗
  • python for循环删除元素
  • div-d和div-i
  • Excel表格如何导出
  • 税务局开蔬菜普票需要几个点
  • 呼伦贝尔清欠办电话
  • 船舶吨税的税目
  • 三门峡哪个小区是原火葬场
  • 医务人员抗疫补助发放标准最新
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设