mongo 简单查询
db.ansheng.findOne()//返回第一条匹配到的数据
db.ansheng.findOne({"aaaaa":4})
db.ansheng.find()//最简单的查询
db.ansheng.find({"aaaaa":2})//返回匹配到的数据
db.ansheng.find({"aaaaa":2}).limit(1)//根据查询条件(find)返回指定条数(limit)的数据
db.ansheng.find({"aaaaa":2}).skip(1).limit(1);//根据查询条件(find)命中N条数据,跳过前(skip)条数据,返回(limit)条数据
db.ansheng.find({"aaaaa":2}, "book":["在绝望中寻找希望"])
db.ansheng1.find({aaa:123, bbb:3211})//多个查询语句

返回指定的键
有时并不需要把文档中所有的键/值对都返回,这时候可以用find的第二个参数来返回指定的键
db.ansheng.find({},{aaaaa:1, list:1})
db.ansheng.findOne({},{aaaaa:1, list:1})
默认下_id总是被返回的,这时候可以使用第二个参数剔除掉他
db.ansheng.find({},{_id:0,aaaaa:1})
db.ansheng.find({},{_id:0})//如果只输入 0 的话,别的参数会全部返回

指定范围的查询
查询中我们经常会遇到大于多少
"$lt"、"$lte"、"$gt"、"$gte"分别对应
<         <=    >    >=

db.ansheng.find({"aaaaa":{"$lt":6,"$gt":3}})
aaaaa 大于3 小于6 的数据

db.ansheng.find({AddTime:{"$lt":new Date("05/05/2016")}})
时间类型的判断

  

in

日常查询中我们我们经常会遇到,根据一组ID或者别的数据进行查询,这个时候我们就需要使用$in这个查询器了

db.ansheng.find({aaaaa:{"$in":[2,3,4]}})

nin

$nin是和in相对应的,nin是返回与数组中都不匹配的数据

db.ansheng.find({aaaaa:{"$nin":[2,3,4]}})

or

or是或者的意思,只要满足 aaaaa = 3或者 flag = true两个任何一个条件,这条数据就会返回

db.ansheng.find({"$or":[{aaaaa:3},{flag:true}]})

nor

$nor 和 or 的意思正好相反 返回不满足指定条件的数据

db.ansheng.find({"$nor":[{aaaaa:3},{flag:true}]})

and

返回满足多个指定条件的数据

db.ansheng.find({"$and":[{aaaaa:2},{flag:true}]})

mod

$mod 是一个取模运算符,他会把查询的值除以第一个给定值,诺余数等于第二个给定值则匹配成功

db.ansheng.find({"aaaaa":{"$mod":[2,1]}}) 返回了 5、7、3  三条数据都满足除以2余1的条件

not

db.ansheng.find({"aaaaa":{"$not":{"$mod":[2,1]}}}) 上面的mod返回了  5、7、3 ,这个就返回除了  5、7、3 以外的数据

特定类型的查询

null

null类型有点奇怪

{ "_id" : ObjectId("572ab6c9734e0336c344e8b4"), "q" : 0 }
{ "_id" : ObjectId("572ab6c9734e0336c344e8b5"), "q" : 1 }
{ "_id" : ObjectId("572ab6c9734e0336c344e8b6"), "q" : 2 }
{ "_id" : ObjectId("572ab6c9734e0336c344e8b7"), "q" : 3 }
{ "_id" : ObjectId("572ab6c9734e0336c344e8b8"), "q" : 4 }
{ "_id" : ObjectId("572ab6c9734e0336c344e8b9"), "q" : 5 }
{ "_id" : ObjectId("572ab6c9734e0336c344e8ba"), "q" : null }
{ "_id" : ObjectId("572ab6c9734e0336c344e8bb"), "q" : null }
{ "_id" : ObjectId("572ab6c9734e0336c344e8bc"), "q" : null }
{ "_id" : ObjectId("572ab6c9734e0336c344e8bd"), "q" : null }
{ "_id" : ObjectId("572ab6c9734e0336c344e8be"), "q" : null }

由上面一个文档在这个文档中 前6条数据 q 都不为null

后5条数据q = null

db.ansheng2.find({q:null}) //这种方式确实可以匹配到 后面5条数据
db.ansheng2.find({qq:null})  //但是这种方式就有问题了他匹配到了全部的数据

db.ansheng2.find({qq:{"$in":[null],"$exists":true}}) 使用了 exists 就可以匹配成功了  0 条数据

更新中

Mongo简单查询总结的更多相关文章

  1. T-SQL简单查询语句

    简单查询: 1.最简单查询(查所有数据)select * from 表名: 注:* 代表所有列select * from info 2.查询指定列select code,name from info ...

  2. MySQL数据库6 -查询基础,简单查询,条件查询,对查询结果排序

    一.SELECT语句 SELECT COL1,COL2,....COLn FROM TABLE1,TABLE2,....TABLEn [WHERE CONDITIONS] -- 查询条件 [GROUP ...

  3. Linq的简单查询

    Ling的简单查询,记在这里防止忘记,以便随时能够查看 List<int> intArr = new List<int>(); || i == select i; List&l ...

  4. Oracle单表的简单查询

    Oracle单表的简单查询 查看表结构 desc emp; 查询所有列 Select * from emp; 查找所以部门编号(查指定的列) select deptnofrom emp; 查找编号不同 ...

  5. Oracle多表的简单查询

    Oracle多表的简单查询 .多表查询 多表查询是指基于两个和两个以上的表或是视图的查询. 问题:显示雇员名,雇员工资及所在部门的名字[笛卡尔集]? select t.ename,t.sal,t1.d ...

  6. Oracle笔记(1) 简单查询、限定查询、数据的排序

    Oracle笔记(四) 简单查询.限定查询.数据的排序   一.简单查询 SQL(Structured Query Language) 结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及 ...

  7. LINQ to Sql系列二 简单查询和联接查询

    这一篇文章主要总结LINQ to sql的简单查询(单表查询)和联接查询(多表查询) 单表查询 需求是我们要输出TClass表中的结果.使用了from-in-select语句,代码如下: public ...

  8. SQL CRUD 简单查询

    identity 自增长 primary key 主键 unique 唯一键 not null 非空 references 外键(引用) 1.删除表 drop table Student 2.修改表 ...

  9. Spring Data JPA 简单查询--接口方法

    一.接口方法整理速查 下表针对于简单查询,即JpaRepository接口(继承了CrudRepository接口.PagingAndSortingRepository接口)中的可访问方法进行整理.( ...

随机推荐

  1. android 自定义相机画面倒立解决方案

    有部分手机的影像是倒立的,如何解决这个问题呢? 请看下面 public static void setCameraDisplayOrientation(Activity activity, int c ...

  2. Fragment基础讲解

    //新建一个碎片public class LeftFragment extends Fragment { @Override public View onCreateView(LayoutInflat ...

  3. Kefa and Park

    #include<bits/stdc++.h> #define max 100005 using namespace std; int cats[max]; vector<int&g ...

  4. 微信公众平台开发3:订阅事件subscribe处理

    新用户关注微信公众平台,将产生一个订阅事件,即subscribe事件,默认代码中没有对这一事件进行相应处理. 在新用户关注公众平台后,可能想知道该平台提供了哪些功能,以及怎样使用该平台,通俗一点讲就是 ...

  5. BZOJ3658 : Jabberwocky

    考虑将某线段下方的点取走: 将所有点从低到高排序 每扫描到一条水平线,对于上面每个点,找到它下面同色的前驱后继,统计中间点的个数 然后再把线上所有点插入数据结构中 最后再统计相邻的同色的点之间的点个数 ...

  6. BZOJ3853 : GCD Array

    1 n d v相当于给$a[x]+=v[\gcd(x,n)=d]$ \[\begin{eqnarray*}&&v[\gcd(x,n)=d]\\&=&v[\gcd(\fr ...

  7. Quest Central for DataBase 5.0.1,6.1 (软件+注册)

    找寻了多天,终于找到了,记录下,以后重装用.输入所有组件的licenses后,提示要注册,我选择了Canada,Google了一个地方的PostCode和phone number,填写,注册成功! 软 ...

  8. Codeforces Round #192 (Div. 2) B. Road Construction

    #include <iostream> #include <vector> using namespace std; int main(){ int n,m; cin > ...

  9. 对偶图 && 【BZOJ】1001: [BeiJing2006]狼抓兔子(对偶图+最短路)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1001 可谓惨不忍睹,一下午就在调这题了. 很久以前看到这题是一眼最大流,看到n<=1000,我 ...

  10. Add Customerlize Button in More Button List In Odoo

    There're two commen type of actions in odoo: ir.actions.server,ir.actions.client_multi 1.Using ir.ac ...