MongoDB文档查询操作(三)

关于MongoDB中的查询,我们已经连着介绍了两篇文章了,本文我们来介绍另外一个查询概念游标

本文是MongoDB系列的第七篇文章,了解前面的文章有助于更好的理解本文。


基本操作

游标这个概念在很多地方都有,Java中JDBC里的ResultSet,Android中的Cursor等等都是,MongoDB中也有类似的概念。当我们调用find方法时,就可以返回一个游标,如下:

var cursor = db.sang_collect.find();

游标中有hasNext()方法,也有next()方法,这两个方法结合可以用来遍历结果,如下:

while(cursor.hasNext()){
    print(cursor.next())
}

next()方法可以获取查询到的每一个文档,如下:

{
    "_id" : ObjectId("59f299579babb96c21ddc9e8"),
    "x" : 0.0,
    "y" : 1000.0
}

/* 2 */
{
    "_id" : ObjectId("59f299579babb96c21ddc9e9"),
    "x" : 1.0,
    "y" : 999.0
}

如果我只想获取文档中的某一个字段,可以按如下方式:

while(cursor.hasNext()){
    print(cursor.next().y)
}

cursor也实现了JavaScript中的迭代器接口,所以我们也可以直接调用forEach方法来遍历:

cursor.forEach(function(x){
    print(x)
    })

当我们调用find方法获取cursor时,shell并不会立即查询数据库,而是在真正使用数据时才会去加载,这有点类似于数据库框架中的懒加载,shell在每次查询的时候会获取前100条结果或者前4MB数据(两者之间取最小),然后我们调用hasNext和next时shell就不用再去连接数据库了,直接一条一条的返回查询到的数据,这100条或者4MB数据全部被返回之后,shell才会再次发起请求向MongoDB要数据。

limit

limit是cursor中的方法,用来限制返回结果的数量,比如我只想获取查询的前三条结果,方式如下:

var cursor = db.sang_collect.find().limit(3)

skip

skip也是cursor中的方法,用来表示跳过的记录数,比如我想获取第2到第5条记录,如下:

var cursor = db.sang_collect.find().skip(2).limit(4)

跳过前两条(0和1)然后获取后面4条数据,skip和limit结合有点类似于MySQL中的limit,可以用来做分页,不过这种分页方式效率过低。

sort

sort用来实现排序功能,比如按x排序,如下:

var cursor = db.sang_collect.find().sort({x:-1})

1表示升序,-1表示降序。

好了,MongoDB中的查询我们就说到这里,小伙伴们有问题欢迎留言讨论。

参考资料:

1.《MongoDB权威指南第2版》

原文发布于微信公众号 - 玩转JavaEE(gh_d1ca11234a30)

原文发表时间:2017-11-29

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏IT笔记

Linux下安装Redis3

下载 下载地址 http://redis.io/download Linux 下执行 wget http://download.redis.io/relea...

3725
来自专栏黑泽君的专栏

c语言基础学习10_关于文件操作的复习

============================================================================= 如果...

940
来自专栏java 成神之路

JVM 类加载机制深入浅出

27211
来自专栏Java成长之路

volatile变量详解

关键字volatile可以说是Java虚拟机提供的最轻量级的同步机制,但是它并不容易完全被正确、 完整地理解,以至于许多程序员都习惯不去使用它,遇到需要处理多线...

1162
来自专栏noteless

-1-5 java 多线程 概念 进程 线程区别联系 java创建线程方式 线程组 线程池概念 线程安全 同步 同步代码块 Lock锁 sleep()和wait()方法的区别 为什么wait(),

java 多线程 概念 进程 线程区别联系 java创建线程方式 线程组 线程池概念 线程安全 同步 同步代码块 Lock锁  sleep()和wait()方法...

1144
来自专栏PPV课数据科学社区

python多线程编程(2): 线程的创建、启动、挂起和退出

如上一节,python 的threading.Thread类有一个run方法,用于定义线程的功能函数,可以在自己的线程类中覆盖该方法。而创建自己的线程实例后,通...

2466
来自专栏Java架构沉思录

你真的懂volatile关键字吗

volatile这个关键字可能很多朋友都听说过,或许也都用过。在Java 5之前,它是一个备受争议的关键字,因为在程序中使用它往往会导致出人意料的结...

1211
来自专栏Java帮帮-微信公众号-技术文章全总结

03.线程安全/同步/线程通讯

03.线程安全/同步/线程通讯 一.一个典型的Java线程安全例子 ? ? 上面例子很容易理解,有一张银行卡,里面有1000的余额,程序模拟你和你老婆同时在取款...

3507
来自专栏大内老A

.NET Core采用的全新配置系统[3]: “Options模式”下的配置是如何绑定为Options对象

配置的原子结构就是单纯的键值对,并且键和值都是字符串,但是在真正的项目开发中我们一般不会单纯地以键值对的形式来使用配置。值得推荐的做法就是采用《.NET Cor...

19610
来自专栏写代码的海盗

scala actor编程之对象传递

scala 最吸引人的一点就是actor并发编程了。但是纵观scala官方文档,baidu文档,IBM文档都写的通过字符串传呀传,如果用作actor编程说明当然...

2919

扫码关注云+社区

领取腾讯云代金券