1. 按条件查询:

db.users.find({"name":"MM1"})

2.find的第二个参数可以指定要返回的字段:这里1 表示要显示的字段,0 表示要剔除的字段

db.users.find({"name":"MM1"},{"name":1,"age":1})
db.users.find({"name":"MM1"},{"name":0})

3. 查询条件: "$lt","$lte","$gt","$gte": <,<=,>,>=

db.users.find({"age":{"$lte":70,"$gte":30}})

4. $in : 匹配指定键的多个值,; $nin和$in相反 $or 匹配多个键的值; $mod取模,将给定值除以第一个数,若余数等于第二个数就返回这条数据

db.users.find({"age":{"$in":[20,25,30]}})
db.users.find({"age":{"$nin":[20,25,30]}})
db.users.find({"$or":[{"age":20},{"winner":"true"}]})
db.users.find({"age":{"$mod":[20,5]}})
db.users.find({"age":{"$not":{"$mod":[20,5]}}})

5. 查询null:

db.users.find({"name":null}) //这样查询出来的还会匹配不包含该键(name)的文档
db.users.fin({"name":{"$in":[null],"$exists":true}}) //使用$exists,就可以准确查出

6. 数组查询:

db.users.find({"fruit":"apple"}) //查询含有apple的数组
db.users.find({"fruit":{"$all":["apple","banana"]}}) //查询包含有apple和banana的数组
db.users.find({"fruit.1":"banana"})//查询数组中第二值为banana的数组,数组是从0开始的

7. 根据数组长度查询:

db.users.find({"fruit":{"$size":3}})
//$size不能和$gte,$lte等合用,可以通过在更新数据时插入一个size字段解决

8. $slice 限制返回的文档数
9. 尽量不使用$where: (1) 查询速度慢-->每个文档都要从BSON转换为js对象,然后通过$where表达式运行; (2)不能使用索引;

10. limit,skip,sort

db.users.find().limit().skip().sort({"name":})

避免使用skip略过大量结果. 否则速度会很慢,原因是:首先要找到这些要略过的数据,然后再抛弃这些数据;不使用skip分页的方法:

//(1)获取第一页
var page1=db.users.find().sort({"date"-1}).limit(20)
//(2)使用最后一个date作为查询条件来获取下一页
var lastest=null
whlie(page1.hasNext)){
lastest=page1.next();
}
var page2=db.users.find({"date":{"$gt":lastest.date}}).sort({"date":-1}).limit(20)

11. 获取随机文档 : 在保存数据时就插入一个随机字段,查询时根据生成的随机数来查找文档

//插入数据
db.users.insert({"name":"11","age":22,"random":Math.random()})
db.users.insert({"name":"11","age":22,"random":Math.random()})
db.users.insert({"name":"11","age":22,"random":Math.random()})
db.users.insert({"name":"11","age":22,"random":Math.random()})
db.users.insert({"name":"11","age":22,"random":Math.random()}) //查询随机文档
var random=Math.random();
db.users.find({"random":{"$gt":random}})
//如果为空可以换为$lt

mongodb学习(五) 查询的更多相关文章

  1. [转载]MongoDB学习 (五):查询操作符(Query Operators).1st

    本文地址:http://www.cnblogs.com/egger/archive/2013/05/04/3059374.html   欢迎转载 ,请保留此链接๑•́ ₃•̀๑! 查询操作符(Quer ...

  2. 【转】MongoDB学习笔记(查询)

    原文地址 MongoDB学习笔记(查询) 基本查询: 构造查询数据. > db.test.findOne() { "_id" : ObjectId("4fd58ec ...

  3. MongoDB 学习五:索引

    这章我们介绍MongoDB的索引,用来优化查询. 索引介绍 数据库索引有些类似书的目录. 一个查询如果没有使用索引被称为表扫描,意思是它必须像阅读整本书那样去获取一个查询结果.一般来说,我们应尽量避免 ...

  4. MongoDB学习笔记-查询

    MongoDB中使用find或findOne函数执行查询 find函数 db.c.find()--查询集合c所有 db.c.find({“name”:”zhangsan”}) 注意:查询条件的值必须是 ...

  5. MongoDB学习--高级查询 [聚合Group]

    Group大约需要一下几个参数. key:用来分组文档的字段.和keyf两者必须有一个 keyf:可以接受一个javascript函数.用来动态的确定分组文档的字段.和key两者必须有一个 initi ...

  6. MongoDB学习记录

    一.操作符 "$lt" :"<""$lte" :"<=""$gt" :"> ...

  7. MongoDB学习笔记(五)--复制集 && sharding分片

    主从复制                                                                                       主从节点开启 主节 ...

  8. MongoDB学习笔记(五、MongoDB存储引擎与索引)

    目录: mongoDB存储引擎 mongoDB索引 索引的属性 MongoDB查询优化 mongoDB存储引擎: 目前mongoDB的存储引擎分为三种: 1.WiredTiger存储引擎: a.Con ...

  9. MongoDB学习笔记(五)

    MongoDB 查看执行计划 MongoDB 中的 explain() 函数可以帮助我们查看查询相关的信息,这有助于我们快速查找到搜索瓶颈进而解决它,本文我们就来看看 explain() 的一些用法及 ...

随机推荐

  1. cocos2d-x 3.3 显示中文

    Resources文件夹下的strings.xml: <dict> <key>targetScore</key> <string>目标分数</st ...

  2. Linux学习 -- 系统管理

    1 进程管理 判断服务器健康状态 top [选项] 查看系统中所有进程 ps aux      BSD格式 ps -le        Linux格式 pstree [选项] -p   显示PID - ...

  3. CD冷却效果实现

    在NGUI中实现CD转圈的特效,可以用图片控件中UISprite组件的Fill Amount属性去控制. 在上图中skill表示需要冷却技能的图片:其子控件Label表示右下角的快捷键“Y”:子控件S ...

  4. CentOS添加字体

    到Windows XP或者Vista下复制字体到CentOS 1.到Windows XP或者Vista下复制字体到CentOS 雅黑:msyh 黑体:SimHei 宋体:SimSun 华文细黑:STX ...

  5. 注意:MainActivity的oncreate方法里不要再inflate布局了(MainActivity里的点击事件无响应)

    activity_main已经通过setContentView(R.layout.activity_main);设置给MainActivity, 不要再inflate出新布局,然后findviewby ...

  6. c++ 显示调用dll

    首先需要引入:#include<windows.h>     否则会出现 HINSTANCE 未定义的错误

  7. call_grant_exec.sql

    set echo off feedback off verify off pagesize 0 linesize 120 define v_grantee                 = & ...

  8. As Fast As Possible

    As Fast As Possible On vacations n pupils decided to go on excursion and gather all together. They n ...

  9. Qt5:Qt中图片的翻转,旋转,缩放,扭曲操作

    具体用到了  mirror()  shear()  scaled() translate() rotate() 等函数函数等会儿再写 (其中  translate() 和 rotate() 俩函数组合 ...

  10. Linux服务器自动备份压缩MySQL数据库的实用方法

    <?php$server = 'localhost'; $link = mysql_connect($server, 'root', 'haven'); $result = mysql_quer ...