mongodb学习04 操作详解(2)
查找文档
筛选查找
db.collection.find();
- 返回一个集合中文档的子集,子集的 范围从 0 个文档到整个集合;
db.collection.findOne();
- 返回筛选的一个文档;
指定返回键
- 设置第二参数,在第一参数筛选后的文档中只返回第二参数设置的键值;默认包含
_id
- 也可以在第二参数中设置
_id: 0
去掉_id
;
//返回name,age,_id
db.test.find({}, {name: 1, age: 1});
//去掉_id
db.test.find({}, {name: 1, age: 1, _id: 0});
查询条件
$lt : <
;$lte: <=
;$gt: >
;$gte: >=
;$ne: !=
;
db.users.find({"age" : {"$gte" : 18, "$lte" : 30}})
OR查询
- 使用
$in
来查询一个键匹配的多个值; - 使用
$nin
来查询一个键不匹配的多个值; - 使用
$or
查询多个键中查询任意的给定值; - 使用
$and
查询多个键中同时匹配的给定值; - 使用
$not
: 取反,可以用在任何其他条件之上;
db.users.find({"user_id" : {"$in" : [12345, "joe"]})
//
db.raffle.find({"ticket_no" : {"$nin" : [725, 542, 390]}})
//查询ticket_no=725或winner=true的元素;
db.raffle.find({"$or" : [{"ticket_no" : 725}, {"winner" : true}]})
//
db.users.find({"$and" : [{"x" : {"$lt" : 1}}, {"x" : 4}]})
//
db.raffle.find({"ticket_no" : {"$not": {"$nin" : [725, 542, 390]}}})
特定数值查询
$mod
: 取模运算,查询的值除以第一个给定值,若余数等于第二个给定值则匹配成功;
db.users.find({"id_num" : {"$mod" : [5, 1]}})
条件语句
- 条件语句是内层文档的键,而修改器则是外层文档的键;
- 一个键可以有任意多个条件,但是一个键不能对应多个更新修改器;
- 有一些“元操作符”(meta-operator)也位于外层文档中,比如
$and
,$or
和$nor
;
查询特定类型
- null: 直接查询还会匹配不包含这个键的文档,可以通过
$exists
条件判定键值已存在;
db.c.find({"z" : {"$in" : [null], "$exists" : true}})
- 正则表达式:MongoDB 使用 Perl 兼容的正则表达式(PCRE)库来匹配正则表达式;
db.users.find({"name" : /joey?/i})
查询数组: 与查询标量值是一样的;
$all
:与$in
不同,查询一个键同时匹配的多个值;- 查询数组特定位置的元素,需使用 key.index 语法指定下标;
$size
: 查询特定长度的数组;并不能与其他查询条件组合使用,但是这种查询可以通过在文档中添加一个size
键的方式来实现;每一次向指定数组添加元素时,同时增加size
的值;$slice
: 指定find
的第二个参数,指定需要返回的键;表示特定的范围;- 在不知道元素下标时希望返回与查询条件 相匹配的任意一个数组元素,使用
$
操作符得到一个匹配的元素;
* 使用$elemMath
同时使用查询条件中的两个语句与 一个数组元素进行比较;但不会匹配非数组元素; - 可以使用
min()
和max()
将查询条件遍历的索引范围限制为$gt
和$lt
的值;在可能包含数组的文档上应用范围查询时使用更好;
db.foot.find({"fruit" : {"$all" : ["apple", "banana"]});
//
db.food.find({"fruit" : {"$size" : 3}});
//返回博客评论的后10条;
db.blog.posts.findOne(criteria, {"comments" : {"$slice" : -10}})
//返回24~33的元素;
db.blog.posts.findOne(criteria, {"comments" : {"$slice" : [23, 10]}})
//
db.blog.posts.find({"comments.name" : "bob"}, {"comments.$" : 1});
//
db.test.find({"x" : {"$elemMatch" : {"$gt" : 10, "$lt" : 20}});
//
db.test.find({"x" : {"$gt" : 10, "$lt" : 20}).min({"x" : 10}).max({"x" : 20});
- 查询内嵌文档:可以使用点表示法查询内嵌文档的键:
db.people.find({"name.first" : "Joe", "name.last" : "Schmoe"})
$where
查询
- 当使用键 / 值方式无法满足时,可以使用
$where
,可以在查询中执行任意的JavaScript
; - 不是非常必要时,一定要避免使用
$where
查询,因为它们在速度上要比常规 查询慢很多; - 每个文档都要从
BSON
转换成JavaScript
对象,然后通过$where
表达式来运行;
//返回两个键具有相同值的文档
db.foo.find({"$where" : function () {
for (var current in this) {
for (var other in this) {
if(current != other && this[current] == this[other]) {
return true;
}
}
}
return false;
}});
- 可以在运行
mongod
时指定--noscripting
选项,完全关闭JavaScript
的执行;
游标
- 可以限制结果的数量,略过部分结果,根据任意键按任意顺序的 组合对结果进行各种排序,或者是执行其他一些强大的操作;
- 调用
find
时,shell
并不立即查询数据库,而是等待真正开始要求获得结果时才发 送查询,这样在执行之前可以给查询附加额外的选项;
hasNext, next
方法
var cursor = db.collection.find();
while (cursor.hasNext()) {
obj = cursor.next();
// do stuff
}
limit,skip
方法
- 避免使用skip略过大量结果,因为先查找后过滤;
- 不用skip对结果分页;
- 不用skip随机选取文档;最好的方法是插入文档时给每个文档都添加一个额外的随机键;
//指定限制个数上限
db.c.find().limit(3);
//跳过最先匹配的3个
db.c.find().skip(3);
sort
:
- 接受一组键 / 值对,键对应文档的键名,值代表排序的方向。
- 排序方向1(升序)或者
mongodb学习04 操作详解(2)的更多相关文章
- mongodb学习03 操作详解
插入文档 db.test.insert({"name":"jinks"}); 批量插入 db.test.insert([{}, {}, {}]); 一次批量插入 ...
- mongodb学习05 操作详解(3)
高级查询选项 //简单查询 var cursor = db.foo.find({"foo" : "bar"}) //封装查询 var cursor = db.f ...
- 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执 ...
随机推荐
- cmd导入oracle数据
ctrl+r 输入imp
- log4j介绍以及使用教程
一.介绍 Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件.甚至是套接 口服务 器.NT的事件记录器.UNIX Syslog ...
- Mac平台下Opencv开发环境搭建
OpenCV(Open Source Computer Vision Library),是一个开源的跨平台的计算机视觉库,它实现了图像处理和计算机视觉领域的很多通用算法,可以在多种计算机平台上运行,支 ...
- NYOJ之茵茵的第一课
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAtQAAAJ/CAIAAADXlNOKAAAgAElEQVR4nO3dsVLjOsMG4P8m6LkQ2u
- Java并发编程中的阻塞和中断
>>线程的状态转换 线程的状态转换是线程控制的基础,下面这张图片非常直观的展示了线程的状态转换: 线程间的状态转换: 1. 新建(new):新创建了一个线程对象.2. 可运行(runnab ...
- 谈谈Delphi中的类和对象1---介绍几个概念 && 对象是一个地地道道的指针
参考:http://blog.163.com/liang_liu99/blog/static/88415216200952123412180/ 以下的介绍主要针对的是Delphi的面向对象的知识,可能 ...
- Delphi面向对象的可见性表示符
Delphi能通过在声明域和方法的时候用protected.private.public.published和automated指示符来对对象提供进一步的控制.使用这些关键字的语法如下 TSomeOb ...
- 【JAVA中String、StringBuffer、StringBuilder类的使用】
一.String类概述 1.String对象一旦创建就不能改变. 2.字符串常量池. 字符串常量池的特点:池中有则直接使用,池中没有则创建新的字符串常量. 例1: public class Strin ...
- 关于python装饰器(Decorators)最底层理解的一句话
一个decorator只是一个带有一个函数作为参数并返回一个替换函数的闭包. http://www.xxx.com/html/2016/pythonhexinbiancheng_0718/1044.h ...
- POJ2778 DNA Sequence(AC自动机 矩阵)
先使用AC自动机求得状态转移关系,再建立矩阵,mat[i][j]表示一步可从i到j且i,j节点均非终止字符的方案数,则此矩阵的n次方表示n步从i,到j的方法数. #include<cstdio& ...
- mongodb学习03 操作详解