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—获取网络数据

    取网络数据主要靠发交易(或者说请求,接口等),而这些交易由java中的网络通信,HttpURLConnection和HttpClient实现,以下是具体例子.   大家都知道,网络通信,发送请求有两种 ...

  2. invokedynamic指令

    Java虚拟机的字节码指令集的数量从Sun公司的第一款Java虚拟机问世至JDK 7来临之前的十余年时间里,一直没有发生任何变化.随着JDK 7的发布,字节码指令集终于迎来了第一位新成员--invok ...

  3. [LintCode] Word Break

    Given a string s and a dictionary of words dict, determine if s can be break into a space-separated ...

  4. unity scroolView 和 groupview

    #pragma strict var scrollPosition:Vector2; function Start () { scrollPosition[0]=50; scrollPosition[ ...

  5. BZOJ 1856 字符串(组合)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1856 题意:有n个1和m个0组成的串,使得任意前k个中1的个数不少于0的个数.有多少种这 ...

  6. javascript第四弹——变量、作用域、内存

    一.变量 定义 变量是松散型的 变量是保存特定值的一个名字 变量包含两种数据类型的值:基本数据类型的值和引用数据类型的值 基本数据类型值 基本数据类型值是一个简单的数据段,在内存中占用固定的空间,保存 ...

  7. HTML中为何P标签内不可包含块元素?

    起因:在做项目时发现原本在DW中无误的代码到了MyEclipse6.0里面却提示N多错误,甚是诧异.于是究其原因,发现块级元素P内是不能嵌套DIV的. 深究:我们先来认识in-line内联元素和blo ...

  8. 【C语言】08-数组

    为了让大家更好地学习和理解数组,我们先来认识一下内存中的"地址". 地址 1.计算机中的内存是以字节为单位的存储空间.内存的每一个字节都有一个唯一的编号,这个编号就称为地址.凡存放 ...

  9. php中alert弹出时单双引号问题

    php代码中单双引号问题是个很重要的问题,使用不当会造成很多麻烦.先记录一下今天写alert遇到的麻烦.我做登录的时候,成功时想弹出个提示说登录成功.写alert语句时不显示.其实就是单双引号弄得不对 ...

  10. Html - 对话箭头

    对话箭头 <!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="U ...