游标是什么?

通俗的说游标不是查询结果,而是查询的返回资源,或者说是查询返回的接口。

通过这个接口,我们可以逐条读取数据。

就像php中我们使用fopen打开文件,得到的是一个资源,通过这个资源,我们可以一行一行的读取这个文件

1.声明游标:

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

cursor.hasNext();判断游标是否已经渠道尽头

cursor.Next();取出游标的下一个单元

其实就是把我们查询时候用到的语句db.collectionName.find();,赋值给一个变量

2.用while来循环游标

var mycursor = db.bar.find({_id:{$lte:5}});

while(mycursor.hasNext()){

//mycursor.next()取出的是bson格式,所以需要用printjson来转换一下

printjson(mycursor.next());

}

3.使用for来循环游标

4.通过cursor一次性得到所有数据,并返回数组

例:

var cursor=db.goods.find();

printjson(cursor.toArray());//看到所有行

printjson(cursor.toArray()[2]);//看到第2行

注意:不要随意使用toArray()

原因:会把所有的行立即以对象的形式组织在内存里,可以在取出少数几行的时候,用此功能。如果我们要出去很多的数据,我们就没有必要用游标了,直接db.collectionName.find(查询表达式,列);就行。

可以取出数组中某一个位置的值,比如我们取第四个

游标的迭代的回调函数

游标的迭代还可以使用forEach()函数,用这种方式还可以有一个回调函数,我们通过自定义回调函数来逐个处理每个单元

cursor.forEach(函调函数);

例:

//定义回调函数,回调函数有一个参数obj,这个参数,就是游标当前所指向的单元,我们可以通过obj.列名获取某一列的值。

var gettitle=function(obj){print(obj.goods_name)}

//声明游标

var cursor=db.goods.find();

//通过forEach和回调函数,依次处理数据

cursor.forEach(gettitle);

游标在分页中的应用

一般地,假设每页N行,当前是page页,就需要跳过前(page-1)*N行,再取N行,在mysql中,limit(offset,N)来实现

在mongo中,用skip(),limit()函数来实现的

比如我们的游标取到10000行数据,而分页中,每页10行

var mycursor=db.bar.find().skip(9995);//跳过前9995行,从9996行一直取到最后

查询第901页,每页10条,

则是var mycursor=db.bar.find().skip(900*10).limit(10);

我们不使用游标,也可以使用skip()和limit()函数,如下图,直接去掉“var xxx= ”

游标,游标,应该是会游动的,我们每调用一次.next()函数,游标就自动的游向下一个单元。从下面的例子中就可以看出,游标在不停的游动

mongo 游标的更多相关文章

  1. mongo数据删除和游标

    数据删除 db.集合.remove(删除条件,是否只删除一个数据);默认删多条(false)true删除一条db.集合.remove({}) 删除所有元素但集合还在db.集合.drop() 删除集合 ...

  2. mongo中的游标与数据一致性的取舍

    除了特殊注释外,本文的测试结果均基于 spring-data-mongodb:1.10.6.RELEASE(spring-boot-starter:1.5.6.RELEASE),MongoDB 3.0 ...

  3. mongo中游标

    1.手动循环访问游标 mongo中我们常用的查询方式db.collection.find()方法其实返回的就是游标,只不过我们并未给返回的游标分配变量,我们所看到的的查询数据也就是游标自动迭代得出的( ...

  4. src/github.com/mongodb/mongo-go-driver/mongo/cursor.go 游标的简洁实用

    src/github.com/mongodb/mongo-go-driver/mongo/cursor.go // Copyright (C) MongoDB, Inc. 2017-present./ ...

  5. python & mongo问题记录

    背景介绍 使用python操作mongo进行的一些操作记录,为了方便日后可以快速的解决类似问题. 准备工作 为了尽可能简单的说明,我将插入几条简单的数据. from pymongo import Mo ...

  6. MongoDB游标操作(4)

    游标是什么? 通俗的说,游标不是查询结果,而是查询的返回资源,或者接口. 通过这个接口,你可以逐条读取. 声明游标: var cursor =  db.collectioName.find(query ...

  7. [MongoDB]Mongo基本使用:

    汇总: 1. [MongoDB]安装MongoDB2. [MongoDB]Mongo基本使用:3. [MongoDB]MongoDB的优缺点及与关系型数据库的比较4. [MongoDB]MongoDB ...

  8. mongo基本操作

    创建数据库文件的存放位置,比如d:/mongodb/data/db.启动mongodb服务之前需要必须创建数据库文件的存放文件夹,否则命令不会自动创建,而且不能启动成功. 打开cmd(windows键 ...

  9. mongo操作

    详细使用网址:http://blog.csdn.net/xinghebuluo/article/details/7050811 MongoDB基本使用 成功启动MongoDB后,再打开一个命令行窗口输 ...

随机推荐

  1. 【原创】Linux环境下的图形系统和AMD R600显卡编程(5)——AMD显卡显命令处理机制

    通常通过读写设备寄存器对设备进行编程,在X86系统上,有专门的IO指令进行编程,在其他诸如MIPS.SPARC这类系统上,通过将设备的寄存器映射到内存地址空间直接使用读写内存的方式对设备进行编程. R ...

  2. Windows8 上用Ubuntu-Ubuntu启动SSH

    公司刚给配了一个电脑,华硕的超级本8个G的内存,很强大的了,但是系统是64位的windows 8,我用wubi.exe直接安装到系统上,但是开机启动的时候总是下面这个错误,去Ubuntu社区请教,结论 ...

  3. 异步 JavaScript 之理解 macrotask 和 microtask(转)

    这个知识点... https://blog.keifergu.me/2017/03/23/difference-between-javascript-macrotask-and-microtask/? ...

  4. AC日记——The Meeting Place Cannot Be Changed codeforces 780b

    780B - The Meeting Place Cannot Be Changed 思路: 二分答案: 代码: #include <cstdio> #include <cstrin ...

  5. 请教一下16aspx上的源代码要如何在自己的服务器上运行

    很正常呀,,我下载的也有运行不成功的你要去他们16aspx论坛发帖子问这里很少有人回答你这样的问题

  6. (10)C#静态方法,静态字段,静态类,匿名类

    6.静态方法 使用静态方法就可不必用类的实例化调用次函数 class Test { public static void method() { ........ } //当调用一个method()时就 ...

  7. java的IO,AIO简单对比

    以下内容转载lzzzl Channel 通道 Buffer 缓冲区 Selector 选择器 其中Channel对应以前的流,Buffer不是什么新东西,Selector是因为nio可以使用异步的非堵 ...

  8. docker网络及Dockerfile

    1.制作镜像 使用阿里的yum源,网址:https://opsx.alibaba.com/mirror,或者mirrors.aliyun.com,点击帮助,就会有弹框出来. docker pull c ...

  9. 1.13(java学习笔记)异常机制

    异常不同于错误,它是程序运行时产生的未知问题. 如果把程序比喻成一辆汽车,那么汽车开着开着突然前面出现了一个大石头挡住了路,这就叫异常. 那么出现了这个异常我们需要去处理,比如打电话给公路管理局,让它 ...

  10. 【转】Kriging插值法

    einyboy 原文LINK Kriging插值法 克里金法是通过一组具有 z 值的分散点生成估计表面的高级地统计过程.与插值工具集中的其他插值方法不同,选择用于生成输出表面的最佳估算方法之前,有效使 ...