mongo 游标
游标是什么?
通俗的说游标不是查询结果,而是查询的返回资源,或者说是查询返回的接口。
通过这个接口,我们可以逐条读取数据。
就像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 游标的更多相关文章
- mongo数据删除和游标
数据删除 db.集合.remove(删除条件,是否只删除一个数据);默认删多条(false)true删除一条db.集合.remove({}) 删除所有元素但集合还在db.集合.drop() 删除集合 ...
- mongo中的游标与数据一致性的取舍
除了特殊注释外,本文的测试结果均基于 spring-data-mongodb:1.10.6.RELEASE(spring-boot-starter:1.5.6.RELEASE),MongoDB 3.0 ...
- mongo中游标
1.手动循环访问游标 mongo中我们常用的查询方式db.collection.find()方法其实返回的就是游标,只不过我们并未给返回的游标分配变量,我们所看到的的查询数据也就是游标自动迭代得出的( ...
- 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./ ...
- python & mongo问题记录
背景介绍 使用python操作mongo进行的一些操作记录,为了方便日后可以快速的解决类似问题. 准备工作 为了尽可能简单的说明,我将插入几条简单的数据. from pymongo import Mo ...
- MongoDB游标操作(4)
游标是什么? 通俗的说,游标不是查询结果,而是查询的返回资源,或者接口. 通过这个接口,你可以逐条读取. 声明游标: var cursor = db.collectioName.find(query ...
- [MongoDB]Mongo基本使用:
汇总: 1. [MongoDB]安装MongoDB2. [MongoDB]Mongo基本使用:3. [MongoDB]MongoDB的优缺点及与关系型数据库的比较4. [MongoDB]MongoDB ...
- mongo基本操作
创建数据库文件的存放位置,比如d:/mongodb/data/db.启动mongodb服务之前需要必须创建数据库文件的存放文件夹,否则命令不会自动创建,而且不能启动成功. 打开cmd(windows键 ...
- mongo操作
详细使用网址:http://blog.csdn.net/xinghebuluo/article/details/7050811 MongoDB基本使用 成功启动MongoDB后,再打开一个命令行窗口输 ...
随机推荐
- urllib url解析学习
#!/usr/bin/env python # encoding: utf-8 from urllib.parse import * #urlparse:解析url分段 #urlsplit:类似url ...
- vue学习之环境配置
最近在学习vue,就顺手记录一下... 1. 安装 nodejs https://nodejs.org -->注:安装LTS的(LTS为长期稳定版本) 在cmd中输入 node -v 如果显 ...
- 经常用的Jquery图片轮转
1.HTML结构 <div class="main_view"> <div class="window"> ...
- 使用Laravel将数据Excel导出的方法
1.copmposer下载maatwebsite/excel 2.在控制器引入:use Excel; 3.将要导出的数据处理成数组,第一组数据为表的字段名,如图 4.导出成表格 Excel::crea ...
- 腾讯微信支付,程序员是如何让jQuery代码付钱的
微信支付和支付宝支付已经是我们生活中不可确实的两个金融软件了,也是必备的,小编认为小钱用微信,大钱用支付宝. 下面这个图是我们生活中用腾讯微信支付平台的最后一个页面,大家想不想知道这个页面是如果做出来 ...
- 计蒜客 28319.Interesting Integers-类似斐波那契数列-递推思维题 (Benelux Algorithm Programming Contest 2014 Final ACM-ICPC Asia Training League 暑假第一阶段第二场 I)
I. Interesting Integers 传送门 应该是叫思维题吧,反正敲一下脑壳才知道自己哪里写错了.要敢于暴力. 这个题的题意就是给你一个数,让你逆推出递推的最开始的两个数(假设一开始的两个 ...
- POJ 3041.Asteroids-Hungary(匈牙利算法)
Asteroids Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 23963 Accepted: 12989 Descr ...
- Python的Web编程[2] -> WebService技术[0] -> 利用 Python 调用 WebService 接口
WebService技术 / WebService Technology 1 关于webservice / Constants WebService是一种跨编程语言和跨操作系统平台的远程调用技术. W ...
- Web/JAVA 简单题目汇总
[Java标识符,变量.常量] 一.Java合法标识符命名规则 (1)区分字母大小写,标识符长度不限 (2) 英文,Unicode码双字节文字字符(日文,韩文,中文),数字,下划线,$(美元符号)均 ...
- 【转载】【面试经验】PHP中级面试题
By chajian8.com - Last updated: 2012/05/24 21:13:12 - 17 views - Posted in PHP, 职场/生活/面试 - Tags: PHP ...