mongodb学习05 操作详解(3)
高级查询选项
//简单查询
var cursor = db.foo.find({"foo" : "bar"})
//封装查询
var cursor = db.foo.find({"foo" : "bar"}).sort({"x" : 1})
实际情况不是将
{"foo" : "bar"}作为查询直接发送给数据库,而是先将查询封 装在一个更大的文档中;shell会把查询从{"foo" : "bar"}`转换成 {"\(query" : {"foo" : "bar"},"\)orderby" : {"x" : 1}};$maxscan: 指定本次查询中扫描文档数量的上限。
db.foo.find(criteria)._addSpecial("$maxscan", 20)
$min: 查询的开始条件。在这样的查询中,文档必须与索引的键完全匹配。查询中会强 制使用给定的索引。$max: 查询的结束条件。在这样的查询中,文档必须与索引的键完全匹配。查询中会强 制使用给定的索引。$showDiskLoc: 用于显示该条结果在磁盘上的位置。
db.foo.find()._addSpecial('$showDiskLoc',true);
获取一致结果
数据处理通常的做法就是先把数据从 MongoDB 中取出来,然后做一些变换,最后再存回去:
如果结果集比较大,MongoDB 可能会多次返 回同一个文档;



对查询进行快照;如果使用了这个选项,查询就在
_id索引上遍历执行,这样可以保证每个文档只被返回一次。快照会使查询变慢,所以应该只在必要时使用快照。
db.foo.find().snapshot();
游标生命周期
- 服务器端,游标消耗内存和其他资源;
- 所以要在合理的前提下尽量保证尽快释放游标;
- 游标完成匹配结果的迭代时,它 会清除自身;
- 如果客户端的游标已经不在作用域内了,驱动程序会向服务器 发送一条特别的消息,让其销毁游标;
- 如果一个游标在 10 分钟内没有使用的话,数据库游标也会自 动销毁;
- 有时的确希望游标持续的时间长一些,多数驱动程序都实现了一个叫
immortal的函数,或者类似的机制,来告知数据库不要让游标超时销毁。
数据库命令
runCommand
db.runCommand({"drop" : "test"});
db.test.drop()
db.listCommands(): 可以看到所有的数据库命令;
数据库命令工作原理
- 数据库命令总会返回一个包含 "ok" 键的文档。
- 如果 "ok" 的值是 1,说明命令执行 成功了;
- 如果值是 0,命令执行失败,命令的返回文档中就会有一个额外的键
errmsg MongoDB中的命令被实现为一种特在$cmd集合上执行殊类型的查询;
db.runCommand({"drop" : "test"});
db.$cmd.findOne({"drop" : "test"});
- 有些命令需要有管理员权限,而且要在
admin数据库上才能执行;可以使用adminCommand而不是runCommand: - 数据库命令是少数与字段顺序相关的地方之一:命令名称必须是命 令中的第一个字段。
修改时间字符为date类型
db.celebrity_news.find({}).forEach(function(doc) {
db.celebrity_news.update({_id: doc._id}, {$set: {newsTime: new Date(doc.newsTime)}})
})
远程导出数据
mongoexport -h 远程地址 --port 端口 -u 用户名 -p 密码 -d 数据库 -c 集合 -f 字段1,字段2 -o 本地文件名
mongodb学习05 操作详解(3)的更多相关文章
- mongodb学习04 操作详解(2)
查找文档 筛选查找 db.collection.find(); 返回一个集合中文档的子集,子集的 范围从 0 个文档到整个集合; db.collection.findOne(); 返回筛选的一个文档; ...
- mongodb学习03 操作详解
插入文档 db.test.insert({"name":"jinks"}); 批量插入 db.test.insert([{}, {}, {}]); 一次批量插入 ...
- MongoDB各种查询操作详解
这篇文章主要介绍了MongoDB各种查询操作详解,包括比较查询.关联查询.数组查询等,需要的朋友可以参考下 一.find操作 MongoDB中使用find来进行查询,通过指定find的第一个参数可 ...
- js学习--DOM操作详解大全一(浏览器对象)
一.客户端中的window对象 window对象表示当前浏览器的窗口,它是一个顶级对象,我们创建的所有对象.函数.变量都是window对象的成员. window对象自带了一些非常有用的方法.属性. w ...
- js学习--DOM操作详解大全 前奏(认识DOM)
一 . 节点属性 DOM 是树型结构,相应的,可以通过一些节点属性来遍历节点树: 方法 说明 nodeName 节点名称,相当于tagName.属性节点返回属性名,文本节点返回#text.nodeNa ...
- js学习--DOM操作详解大全二(window对象)
一.window - 计时器 1、setTimeout()可以用来在指定的时间之后单次调用函数.setTimeount(f,1000);//一秒后调用函数fclearTimeout();取消函数的执行 ...
- 从51跳cortex-m0学习2——程序详解
跳cortex-m0——思想转变>之后又一入门级文章,在此不敢请老鸟们过目.不过要是老鸟们低头瞅了一眼,发现错误,还请教育之,那更是感激不尽.与Cortex在某些操作方式上的异同,让自己对Cor ...
- MySQL 操作详解
MySQL 操作详解 一.实验简介 本节实验中学习并实践 MySQL 上创建数据库.创建表.查找信息等详细的语法及参数使用方法. 二.创建并使用数据库 1. 创建并选择数据库 使用SHOW语句找出服务 ...
- Hadoop深入学习:MapTask详解
转自:http://flyingdutchman.iteye.com/blog/1878775#bc2337280 Hadoop深入学习:MapTask详解 博客分类: Hadoop MapTask执 ...
随机推荐
- iOS- 如何改变section header
希望这个从UITableViewDelegate协议里得到的方法可以对你有所帮助: - (UIView *) tableView:(UITableView *)tableView viewForHea ...
- Jquery网站下雪花的效果
代码如下: <script type="text/javascript" src="jquery.min.js"></script> & ...
- ssh配置免密码登录
日常工作中很多情况下都需要登录服务器进行管理,一般都是用ssh进行连接,为了防止密码外泄,可以配置下ssh的免密码登录. 首先服务器两台: A:43.224.34.* B:104.238.161.* ...
- java Http原生 Get 和Post 支持代理认证
import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import ...
- Linux中LoadAverage分析
判断系统负荷 1.uptime 命令,load average的三个数分别表示了1分钟.5分钟.15分钟的平均进程数. 如果你继续看手册,它还会告诉你,当CPU完全空闲的时候,平均负荷为0:当CPU工 ...
- 四、优化及调试--网站优化--SEO在网页制作中的应用
SEO分类:白帽SEO.黑帽SEO 白帽SEO: 内容上的SEO: 网站标题.关键字.描述 网站内容优化 Robot.txt文件 网站地图 增加外链引用 前端SEO: 网站结构布局优化 扁平化结构(一 ...
- Android Tab -- 使用Fragment、FragmentManager来实现
原文地址:http://blog.csdn.net/crazy1235/article/details/42678877 效果: 代码:https://github.com/ldb-github/La ...
- MySQL zabbix
http://liqingbiao.blog.51cto.com/3044896/1712080
- Linux内核驱动之GPIO子系统(一)GPIO的使用
转自:http://blog.csdn.net/mirkerson/article/details/8464290 一 概述 Linux内核中gpio是最简单,最常用的资源(和 interrupt , ...
- Visual Studio 2015的Web扩展包
过去几年,Visual Studio扩展功能生态系统得到了蓬勃发展,社区贡献出了大量优秀的扩展,其中也包括大量针对Web开发的扩展.但是很多时候,感觉寻找.安装.更新好 几个扩展,总显得比较麻烦.如果 ...