按条件查询

比较操作:$lt,$lte,$gt,$gte,$ne

db.user.find({"score":{$gt:}});

$or :包含多个条件,他们之间为or的关系 ,$nor相当于or取反

db.user.find({$or:[{"score":{$gt:}},{"user_id":"u3"}]});

$not:用作其他条件之上,取反

$mod:将查询的值除以第一个给定的值,如果余数等于等二个值则匹配成功

db.user.find({"score":{$mod:[,]}});

$in :查询一个键的多个值,只要键匹配其中一个即可 , $nin为不包含

db.user.find({"score":{$in:[,]}});

$all键需要匹配所有的值

db.user.find({"house":{$all:[]}});

$exists:检查某个键是否存在,1表示存在,0表示不存在

db.user.find({"name":{$exists:1}});

null类型:不仅能匹配键的值为null,还匹配键不存在的情况

db.user.find({"name":null});

查询数组

单个元素匹配,就跟前面写条件一样,{key:value}

 db.user.find({"house":});

多个元素匹配,使用$all, {key:{$all:[a,b]}},元素的顺序无所谓

db.user.find({"house":{$all:[,]}});

可以使用索引指定查询数组特定位置, {“key.索引号”:value}

 db.user.find({"house.1":});

查询某个长度的数组,使用$size

db.user.find({"house":{$size:}});

指定子集,使用$slice,正数是前面多少条,负数是尾部多少条,也可以指定偏移量和要返回的元素数量,比如:$slice:[50,10]

db.user.find({"house":{$exists:}},{"house":{$slice:[,]}});

可以使用$来指定符合条件的任意一个数组元素,如:{”users.$”:1}

 db.user.find({"house":{$exists:}},{"house.$":});

$elemMatch:要求同时使用多个条件语句来对一个数组元素进行比较判断

db.user.find({"house":{$elemMatch:{$gte:,$lt:}}});

查询记录条数的命令:count

db.user.find().count();

如果要获取按条件查询后记录的条数,需要指定count(true或者非0的数)

  • 限制返回的记录条数的命令:limit(要返回的条数)
  • 限制返回的记录条数起点的命令:skip(从第几条开始返回)
  • 排序的命令:sort({要排序的字段:1为升序,-1为降序})
db.user.find({}).limit().count();

db.user.find({}).skip(1).limit(2);

 db.user.find({}).sort({"score":1});

分页查询:组合使用limit,skipt和sort
当然也可以使用其他方式来分页,比如采用自定义的id,然后根据id来分页


查询给定键的所有不重复的数据,命令:distinct
语法:db.runCommand({“distinct”:集合名,“key”:”获得不重复数据的字段”});

 db.runCommand({"distinct":"user","key":"user_id"});

存储过程
MongoDB的存储过程其实就是个自定义的js函数
使用db.system.js.save({“_id”:名称,value:函数});

var totalF=function (a,b){ return a+b ;};

db.system.js.save({"_id":"myF","value":totalF});

可以通过如下命令查看:db.system.js.find();
可以通过如下命令调用:db.eval(名称)

db.eval("myF(1,3)");

MongoDB查询操作的更多相关文章

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

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

  2. Spring Boot MongoDB 查询操作 (BasicQuery ,BSON)

    MongoDB 查询有四种方式:Query,TextQuery,BasicQuery 和 Bson ,网上太多关于 Query 的查询方式,本文只记录 BasicQuery和Bson 的方式,Basi ...

  3. MongoDB查询操作 返回指定字段(C#官方驱动)

    首先,MongoDB中返回指定的字段的查询方法如下: db.person.find({Name:"小丑"},{Age:1,Sex:1}) 该语句表示:查询person表中name为 ...

  4. 解析PHP中常见的mongodb查询操作

    详细出处参考:http://www.jb51.net/article/38839.htm<?php// 欄位字串為$querys = array("name"=>&qu ...

  5. MongoDB的查询操作

    1. 前言 在这篇博文中,我们将学习如何查询mongoDB中的数据.当我们把数据存储在mongoDB以后,我们需要把数据查询出来.毕竟CRUD操作中,查询操作在我们系统中是我们应用比较频繁的操作.我们 ...

  6. MongoDB各种查询操作详解

    这篇文章主要介绍了MongoDB各种查询操作详解,包括比较查询.关联查询.数组查询等,需要的朋友可以参考下   一.find操作 MongoDB中使用find来进行查询,通过指定find的第一个参数可 ...

  7. [转] MongoDB shell 操作 (查询)

    最近有用到mongoDB,每次都去查看官方文档很是费劲,自己准备写点东西.但在博客园上看到另外的一篇博文不错,就转载过来,加上点儿自己的修饰 左边是mongodb查询语句,右边是sql语句.对照着用, ...

  8. MongoDB源码分析——mongod数据查询操作

    源码版本为MongoDB 2.6分支 Edit mongod数据查询操作 在mongod的初始化过程中说过,服务端接收到客户端消息后调用MyMessageHandler::process函数处理消息. ...

  9. Mongodb基础用法及查询操作[转载]

    插入多条测试数据> for(i=1;i<=1000;i++){... db.blog.insert({"title":i,"content":&qu ...

随机推荐

  1. 面试题集锦---BY算法导论小组

    3.7题 3.21题 1.给定能随机生成整数 1 到 5 的函数,写出能随机生成整数 1 到 7 的函数. 提示:两个random就可以有25种可能,每种可能都是等概率的 2.判断一个自然数是否是某个 ...

  2. ubuntu dnsmasq

    /var/run/NetworkManager/resolv.conf 而你真实的dns服务器地址,是被这个服务管理维护着的/ local process -> local dnsmasq -& ...

  3. 20165223《网络对抗技术》Exp 9 Web安全基础

    目录 -- Web安全基础 ★ 实验说明 实验目标 基础问答 实验准备 ★ 实验内容 SQL注入攻击 1. 命令注入(Command Injection) 2. 数字型注入(Numeric SQL I ...

  4. T-MAX-凡事预则立

    T-MAX-凡事预则立 这个作业属于哪个课程 2019秋福大软件工程实践Z班 这个作业要求在哪里 团队作业第五次-项目冲刺 团队名称 T-MAX 这个作业的目标 1.冲刺的时间计划安排2.答辩问题的回 ...

  5. ArcGIS数据建模 (模型构建器modelbuilder) 培训视频 5章28小节587分钟视频 51GIS网站上线

    网址:http://www.51gis.com.cn/kecheng.html?id=358

  6. P5662 纪念品

    P5662 纪念品 题解 拿到题目想到DP,但是就是不知道咋写 后来证实这是个背包DP(最近整理背包白整了 我们观察这道题目的特殊之处: 也就是说,对于手中的物品,我们可以今天买了然后明天早上接着卖出 ...

  7. i18n 语言码和对应的语言库

    语言码 语言名称 af Afrikaans am Amharic ar Arabic az Azerbaijani be Belarusian bg Bulgarian bh Bihari bn Be ...

  8. Excel导出问题

    问题一:本地导出正常,部署到linux服务器导出文件内容乱码? 解决:修改服务器tomcat配置 server.xml 添加URIEncoding="UTF-8" <Conn ...

  9. CentOS 端口和防火墙操作

    Centos 7 端口和防火墙命令: 查看已经开放的端口:firewall-cmd --list-ports 开启端口:firewall-cmd --zone=public --add-port=80 ...

  10. LeetCode_83. Remove Duplicates from Sorted List

    83. Remove Duplicates from Sorted List Easy Given a sorted linked list, delete all duplicates such t ...