最近在用这个东西,为防止忘记,记下来。

集合简单查询方法

mongodb语法:db.collection.find()  //collection就是集合的名称,这个可以自己进行创建。

对比sql语句:select * from collection;

查询集合中所有的文档,即关系型数据库中的查询表中的所有数据。

返回制定的键值

mongodb语法:db.collection.find({},{"userid":1})

对比sql语句:select userid from collection;

条件过滤

mongodb语法 : db.collection.find({"userid":495})

对比sql语句:select * from collectionwhere userid = 495;

  

查询全格式书写解释

  db.collection.find({},{})

第一个{}中,写入的都是相当于sql语句中where后的条件,多条件格式为{"key":value,"key2":"value2"}

第二个{}中,写入的都是相当于sql语句中跟在select后边的具体字段,格式为{"key":value,"key2":value}

      当value = 0时为不显示此字段值,当value !=0,即等于任何非0值时,则为显示此字段。

例:

mongodb查询:

db.error.find({"userid":1,"type":"debug"},{"userid":1,"type":1,"myssage":1})

sql查询:

select userid,type,message from error where userid=1 and type = "debug";

sort排序与limit返回固定条目数

mongodb查询:

db.collection.find({"userid":1,"type":"debug"},{"userid":1,"type":1,"myssage":1}).sort("time":-1).limit(10)

sql查询:

select userid,type,message from collection where userid=1 and type = "debug" order by time desc limit 10;

count返回结果集总数

mongodb查询:

db.collection.count()

sql查询:

select count(*) from collection;

查询操作符"$gt" -->大于操作符

mongodb查询:

db.collection.find({"userid":{"$gt":"494"}})

sql查询:

select * from collection where userid > 494;

 

查询操作符"$gte" -->大于等于

mongodb查询:

db.collection.find({"userid":{"$gte":"494"}})

sql查询:

select * from collection where userid >= 494;

 

查询操作符 "$lt"-->小于

mongodb查询:

db.collection.find({"userid":{"$lt":"494"}})

sql查询:

select * from collection where userid <494;

 

查询操作符"$lte"-->小于等于

mongodb查询:

db.collection.find({"userid":{"$lte":"494"}})

sql查询:

select * from collection where userid < =494;

 

查询操作符"$ne"-->不等于

mongodb查询:

db.collection.find({"userid":{"$ne":"494"}})

sql查询:

select * from collection where userid != 494;

 

查询操作符"null查询"-->空

mongodb查询:

db.collection.find({"userid":null})

sql查询:

select * from collection where userid is null;

 

查询操作符"$all"-->匹配所有

mongodb查询:

db.collection.find({"userid":{"$all":"494"}})

sql查询:

select * from collection where userid = 494;

    当文档类型为数组时,使用$all进行匹配,非数组类型使用时与单一匹配一样。


查询操作符"$size"-->用于数组查询,查询指定长度的数组

mongodb查询:

db.collection.find({"remark":{"$size":"3"}})

查询操作符"$in"--> 在范围内

mongodb查询:

db.collection.find({"userid":{"$in":["297","495"]}})

sql查询:

select * from collection where userid in (297,495);


查询操作符"$nin"-->不在范围内

mongodb查询:

db.collection.find({"userid":{"$nin":["297","495"]}})

sql查询:

select * from collection where userid not in (297,495);


查询操作符"$and"-->至少包含两个表达式,两个表达式都满足的文档返回

mongodb查询:

db.collection.find({"$and":[{"userid":"495"},{"type":"info"}]})

sql查询:

select * from collection where userid=495 and type='info';


查询操作符"$nor"-->至少包含两个表达式,两个表达式都不满足的文档返回

mongodb查询:

db.collection.find({"$nor":[{"userid":"495"},{"userid":"297"}]})

sql查询:

select * from collection where userid not in (297,495);


查询操作符"$not"-->找出不匹配表达式的文档,不能够单独使用,必须与其他表达式配合使用

mongodb查询:

db.collection.find({"userid":{"$not":{"$gt":"297"}}})

等同于:db.collection.find({"userid":{"$lte":"297"}}})

sql查询:

select * from collection where userid <=297;


查询操作符"$or"-->至少包含两个表达式,两个表达式至少满足一个的文档返回

mongodb查询:

db.collection.find({"$or":[{"userid":"495"},{"userid":"297"}]})

sql查询:

select * from collection where userid =297 or userid = 495;


查询操作符"$exists"-->查询文档中字段是否存在

mongodb查询:

db.collection.find({"$exists":"true"})


查询操作符"$mod"-->键值对变量参数取模,值等于另一个参数

mongodb查询:

db.collection.find({"userid":{"$mod":[10,7]}})

执行条件:userid字段值必须是数字,userid对10取模,值等于7的文档返回。

sql查询:

select * from collection where (user_id%10)=7


查询操作符"$regex"-->正则匹配

mongodb查询:

db.collection.find({"userid":/5$/})

sql查询:

select * from collection where userid like '%5';

  sql正则写法:      

     select * from collection where userid regexp ".5$";
 
   正则匹配userid的最后一位是5的,sql中只有使用regexp才可以使用复杂的正则表达式,使用Like的方式不可以进行复杂的正则匹配

查询操作符"$slice"-->控制返回的数组元素中的元素个数

mongodb查询:

db.collection.find({},{"remark":{"$slice":5})

remark数组键值,返回数组键值中的前5个元素

db.collection.find({},{"remark":{"$slice":[10,5]})

remark数组键值,返回数组键值中的第11到15个元素,偏移量为10,然后返回5个。

db.collection.find({},{"remark":{"$slice":-5})

remark数组键值,返回数组键值中的后5个元素

逐渐补充中......

Mongodb查询的用法,备注防止忘记的更多相关文章

  1. mongodb 查询的用法

    想要在C#中使用MongoDB,首先得要有个MongoDB支持的C#版的驱动.C#版的驱动貌似有很多种,如官方提供的samus. 实现思路大都类似.这里我们用官方提供的mongo-csharp-dri ...

  2. mongodb查询关于大于小于的用法;

    mongoDB查询操作符: http://www.runoob.com/mongodb/mongodb-operators.html 项目中需要的场景是这样的,每个人每天只能领取一张明信片,换句话说, ...

  3. MongoDb进阶实践之三 MongoDB查询命令详述

    一.引言           上一篇文章我们已经介绍了MongoDB数据库的最基本操作,包括数据库的创建.使用和删除数据库,文档的操作也涉及到了文档的创建.删除.更新和查询,当然也包括集合的创建.重命 ...

  4. MongoDb进阶实践之四 MongoDB查询命令详述

    一.引言 上一篇文章我们已经介绍了MongoDB数据库的最基本操作,包括数据库的创建.使用和删除数据库,文档的操作也涉及到了文档的创建.删除.更新和查询,当然也包括集合的创建.重命名和删除.有了这些基 ...

  5. mongodb聚合管道用法

    基本用法 db.collection.aggregate( [ { <stage> }, ... ] ) stage如下 名称 描述 $addFields 将新的字段添加到文档中,输出的文 ...

  6. 【Mongodb教程 第七课 】MongoDB 查询文档

    find() 方法 要从MongoDB 查询集合数据,需要使用MongoDB 的 find() 方法. 语法 基本的find()方法语法如下 >db.COLLECTION_NAME.find() ...

  7. MongoDB查询转对象是出错Element '_id' does not match any field or property of class

    MongoDB查询转对象是出错Element '_id' does not match any field or property of class   解决方法: 1.在实体类加:[BsonIgno ...

  8. MongoDB查询操作限制返回字段的方法

    这篇文章主要介绍了MongoDB查询操作限制返回字段的方法,需要的朋友可以参考下   映射(projection )声明用来限制所有查询匹配文档的返回字段.projection以文档的形式列举结果集中 ...

  9. mongodb查询文档

    说到查询,我们一般就想起了关系型数据库的查询了,比如:order by(排序).limit(分页).范围查询(大于某个值,小于某个值..,in查询,on查询,like查询等待很多),同样mongodb ...

随机推荐

  1. iOS 进阶 第九天(0408)

    0408 makekeyAndVisible解释 一个程序可以有多个Window,但只有一个窗口能够成为主窗口.如图中所示,此时的window2是主窗口.主窗口用处大了.从iOS7开始无论是主窗口还是 ...

  2. SQLServer2005:在执行批处理时出现错误。错误消息为: 目录名无效

    删除数据时忘了想delete删除的话会记录日志,更何况是我删除百万条数据,结果还没删完服务器内存就占慢了,一切数据都进不来了,估计这种情况导致我的数据库有问题了,右键打开表提示:目录名无效,执行SQL ...

  3. How to use Android Activity's finish(), onDestory() and System.exit(0) methods

    Activity.finish() Calling this method will let the system know that the programmer wants the current ...

  4. html+css学习笔记 4[定位]

    如何让图1中的div2移动到如图2上的位置: 思路:哪些css命令能够影响盒子显示的位置呢? relative相对定位/定位偏移量 position:relative;  相对定位         a ...

  5. ios7去除手势滑动返回

    if ([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) { sel ...

  6. C#中两个日期类型相减得到天数

    protected int GetDuration(DateTime start, DateTime finish) { return (finish - start).Days; } 直接相减得到的 ...

  7. hibernate里createSQLQuery

    一.addEntity()和setResultTransformer()方法 1. 使用SQLQuery 对原生SQL查询执行的控制是通过SQLQuery接口进行的,通过执行Session.creat ...

  8. 【WCF--初入江湖】13 实战

    13 实战 在线升级 using System; using System.Collections.Generic; using System.ComponentModel; using System ...

  9. 01-08-01【Nhibernate (版本3.3.1.4000) 出入江湖】NHibernate中的三种状态

    以下属于不明来源资料: 引入 在程序运行过程中使用对象的方式对数据库进行操作,这必然会产生一系列的持久化类的实例对象.这些对象可能是刚刚创建并准备存储的,也可能是从数据库中查询的,为了区分这些对象,根 ...

  10. Java学习第二篇:类,对象,成员属性,成员方法,构造方法,类变量,类方法

    一.类的定义 一个全面的类定义是比较复杂的,  定义如下: