MongoDB中使用find或findOne函数执行查询

find函数

db.c.find()--查询集合c所有

db.c.find({“name”:”zhangsan”})

注意:查询条件的值必须是常量,也就是说不能用变量

db.c.find({“name”:this.name})//这样是行不通的

查询条件

“$lt”对应<

“$lte”对应<=

“$gt”对应>

“$gte”对应>=

“$ne”对应!=

用法:

db.users.find({“age”:{“$gte”:18,”$lte”:30}})//查找年龄大于等于18小于等于30的用户

db.users.find({“name”:{“$ne”:”张全蛋”}})

OR查询

MongoDB中用两种方式来实现OR查询:

“$in”可以用来查询一个键的多个值,它非常灵活,可以指定不同类型的条件

“$nin”与”$in”作用相反

“$or”可以在多个贱种查询任意的给定值

用法:

db.users.find({“name”:{“$in“ [“王尼玛”,“张全蛋”]}})

db.users.find(“user_id”:{“$in”: [123456,”123456”]})//用户id键的数据类型发生变化时的查找

db.users.find({“name”:{“$or”: [“age”: {“$in”: [18,20,25]},{“gender”:1}]}})

$not

$not是元条件操作符,它可以用在任何其他条件之上。

db.users.find({“id_num”:{“$not”:{“$mod”: [5,1]}}}) //”$mod”是取模运算符

null类型

users集合有三条数据如下:

{“name”:王尼玛”,”age”:18}

{“name”:”张全蛋”,”age”:20}

{“name”:”唐马孺”,”age”:null}

其中“唐马儒”的age为null值

然后查询:db.users.find({“age”:null})

查出来的结果不仅有{“name”:”唐马孺”,”age”:null},其他的两条也会被查出。因为null不仅会匹配某个键值为null的文档,而且还会

匹配不包含这个键的文档。

如果仅想匹配键值为null的文档,那就要用到”$exists”

db.users.find({“age”:  [null],”$exists”:true})

正则表达式

db.users.find({“name”:/张./})

查询数组

db.food.insert({“fruit”: [“apple”,”banana”,”peach”]})

查询:

db.food.find({“fruit”: “banana”})

结果会匹配上面插入的文档

$all:用于查找匹配多个条件下的数组

例如,常见一个包含3个元素的集合:

db.food.insert({“fruit”: [“apple”,”banana”,”peach”]})

db.food.insert({“fruit”: [“apple”,”kumquat”,”orange”]})

db.food.insert({“fruit”: [“cherry”,”banana”,”apple”]})

要找到既有”apple”又有“banana”的文档:

db.food.find({fruit:{$all: [“apple”,”banana”]}})

结果会找出第1个和第3个文档

$size:用于查询特定长度的数组

db.food.find({“fruit”:{“$size”:3}})

按索引匹配:db.food.find({“fruit.2”:”peach”]})

$slice:用于分割find/findOne返回值的结果集,返回某个键匹配的数组元素的子集。

db.food.findOne({},{“fruit”:{“$slice”:2}})

db.food.findOne({},{“fruit”:{“$slice”:-2}})//从右向左

$elemMatch:要求MongoDb同时使用查询条件作用于同一个数组(默认情况下是多个条件作用于多个数组)

db.test.find({“x”:{“$elemMatch”:{“$gt”:10,”$lt”:20}}})

$where查询

$where用于任何查询,它可以执行任意Javascript。因此为了安全起见,应该严格限制或不使用$where。

db.food.find({“$where”:function(){

forvar current in this(){

    //todo

}

}})

使用$where查询时,速度上要比常规查询慢的多,因为它要把每个文档从BSON对象转换成Javascript对象。

limit、skip和sort

limit函数:用于限制查询结果的个数

db.food.find().limit(3) //只返回3个匹配的结果。要是匹配的结果不到3个,则返回匹配数量的结果。

skip函数:用于略过指定个数的文档

db.food.find().skip(1) //略过第1个文档,返回后两个

sort函数:对查询结果进行排序,1是升序,-1是降序

db.food.find().sort({“fruit”:1})

MongoDB学习笔记-查询的更多相关文章

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

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

  2. MongoDB学习笔记系列

    回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...

  3. PHP操作MongoDB学习笔记

    <?php/*** PHP操作MongoDB学习笔记*///*************************//**   连接MongoDB数据库  **////*************** ...

  4. MongoDB 学习笔记(原创)

    MongoDB 学习笔记 mongodb 数据库 nosql 一.数据库的基本概念及操作 SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table ...

  5. mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)

    最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...

  6. MongoDB学习笔记(六)--复制集+sharding分片 && 总结

    复制集+sharding分片                                                               背景 主机 IP 服务及端口 Server A ...

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

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

  8. MongoDB学习笔记(四)--索引 && 性能优化

    索引                                                                                             基础索引 ...

  9. MongoDB学习笔记(二)--Capped集合 && GridFS存储文件

    Capped集合                                                            Capped集合的大小是固定的,如果空间都被用完了,新添加的对象 ...

随机推荐

  1. STM32F05 学习中............

    今天,拿到stm32f05的板子已经三个月了吧,但是没有真的研究过,真的对板子过意不去了...所以决定今天好好的对待我的板子.

  2. 【python】基础

    [字符串]前后引号必须要匹配,相关函数int(),float(),str(),repr(),format(),还有切片运算符 a = 'text'           单引号指定的字符串必须在一个逻辑 ...

  3. 014安装Linux系统到开发板

    SD卡----->开发板 1.安装准备: 硬件连接 USB下载线,一端连到开发板,另一端连到PC机: 串口线连好: 电源线连好: 设置开发板从SD卡启动: 2.打开开发板进入选单界面: 进入选单 ...

  4. 一分钟学会(一):.NET之正则表达式

    本文介绍正则表达式在.NET中的基本应用,代码简单粗暴,实例浅显易懂,让你一分钟快速上手正则(大鸟请略过). 本文为入门文章,很多时候我们只是忘记了语法,这也可作为一个快速查询的参考. 如果想深入学习 ...

  5. 乐够GO应用源码完整版

    乐够GO应用源码完整版 V1.0,系统2.3以上使用,需要联网,每天定时更新数据,实现了对文章赞的功能,以及常用的评论功能,还有生活的职业的相关功能,如查找功能,分类的分类等功能,具体大家可以看看应用 ...

  6. .NET Web开发总结(五)

    7 常用服务器控件 7.1 服务器控件概述 · 服务器控件是指在服务器上执行程序的代码的组件 通常这些服务器控件会提供    给用户一定的界面,  以便用户与服务器之间快速的交互 7.2 HTML 服 ...

  7. Linux manual中命令标号的含义

    如果查看Linux manual(例如,执行:man open), 会发现文档中有这样的表达方式:read(2), write(2), lseek(2), fcntl(2)等,括号中的数值表达什么含义 ...

  8. Jquery动画效果--地铁站名指示等效果

    源码参考:源码爱好者--jQuery仿地铁线路指示灯效果,经修改和美化,特此记录一下. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tra ...

  9. 前端构建工具grunt

    简单配置grunt 配置gulp还是grunt都是在node的环境下安装的,所以在这之前保证你的node环境已经安装好了! -------------------------------------- ...

  10. maraidb半同步复制

    半同步复制是在主从同步复制的基础之上,主从同步前面我的博文有介绍 Semisynchronous Replication(半同步复制)则一定程度上保证提交的事务已经传给了至少一个备库 MySQL在加载 ...