MongoDB 基本操作和聚合操作
一 . MongoDB 基本操作
基本操作可以简单分为查询、插入、更新、删除。
1 文档查询
| 作用 | MySQL SQL | MongoDB |
| 所有记录 | SELECT * FROM users; | db.users.find(); |
| age =18 | SELECT * FROM users WHERE age = 18; | db.users.find({“age”:18}); |
| 筛选字段 | SELECT age FROM users WHERE age = 18; | db.users.find({“age”:18},{age:1}); |
| 排序 | SELECT * FROM users ORDER BY name ASC | db.users.find().sort({name:1}); |
| 比较 | SELECT * FROM users WHERE age > 18; | db.users.find({“age”:{$gt:18}}); |
| 正则 | SELECT * FROM users WHERE name LIKE zha; | db.users.find({“name”:/^zha/}); |
| 忽略 | SELECT * FROM users LIMIT 10 SKIP 20; | db.users.find().limit(10).skip(20); |
| or | SELECT * FROM users WHERE a=1 or b=2; | db.users.find({$or : [{ a : 1} , {b : 2}]}); |
| distinct | SELECT DISTINCT name FROM users; | db.users.distinct(‘name'); |
| count | SELECT COUNT(name) FROM users; | db.users.find({name: {'$exists': true}}).count(); |
2.文档插入
| 作用 | 操作指令(案例) |
| 单文档插入 | db.inventory.insertOne( { item: "canvas", qty: 100, tags: ["cotton"], size: { h: 28, w: 35.5, uom: "cm" } } ) |
| 多文档批量插入 |
db.inventory.insertMany([ { item: "journal", qty: 25, tags: ["blank", "red"], size: { h: 14, w: 21, uom: "cm" } }, { item: "mat", qty: 85, tags: ["gray"], size: { h: 27.9, w: 35.5, uom: "cm" } }, { item: "mousepad", qty: 25, tags: ["gel", "blue"], size: { h: 19, w: 22.85, uom: "cm" } } ]) |
文档大量插入时,通过多文档批量插入的形式可以大大提高性能,但是MongoDB 4.0 之前的版本是单文档事务型,所以,在多文档批量插入时,不能保证所有文档操作的原子性,即插入过程中,如果不幸出现了系统问题,有可能部分文档插入成功,而部分文档插入失败。
3.文档更新
文档更新主要有两种形式,一种是替换修改,一种是通过操作符修改。后者是常见的修改方式,在此主要讲解后者。
| 操作符 | 操作符描述 |
| $inc | 根据给定的值增加字段 |
| $set | 设置字段给定的值 |
| $unset | 取消设置字段 |
| $rename | 重命名字段为给定的值 |
| $setOnInsert |
在upsert中,只在插入时设置字段; 如果要更新的文档存在那么$setOnInsert操作符不做任何处理 |
| $bit | 只执行按位更新字段 |
关于数组数据的更新操作符
| 数组操作符 | 数组操作符描述 |
| $push | 添加值到数组中 |
| $addToSet | 添加值到数组中,重复了也不处理 |
| $pop | 从数组中删除第一个或最后一个值 |
| $pull | 从数组中删除匹配查询条件的值 |
| $eash | 与$push和$addToSet一起使用来操作多个值 |
| $slice | 与$push和$each一起使用来缩小更新后数组的大小 |
4.文档删除
集合数据的删除主要通过remove的命令来删除,类似于关系型数据库中的delete。
二 聚合操作
| MySQL | MongoDB | 功能描述 |
| select | $project | 指定输出文档里的字段 |
| where | $match | 选择要处理的文档,与find()类似 |
| group by | $group | 根据key来分组文档 |
| having | $match | 刷选文档 |
| limit | $limit | 限制传递给下一步的文档数量 |
| order by | $sort | 排序文档 |
| count/sum | $sum | 统计 |
| join | $unwind | 扩展数组,为每个数组入口生成一个输出文档 |
| join | $look up | 表关联 |
| skip | $skip | 跳过一定数据量的文档 |
MongoDB 基本操作和聚合操作的更多相关文章
- MongoDB中的聚合操作
根据MongoDB的文档描述,在MongoDB的聚合操作中,有以下五个聚合命令. 其中,count.distinct和group会提供很基本的功能,至于其他的高级聚合功能(sum.average.ma ...
- MongoDB学习笔记——聚合操作之聚合管道(Aggregation Pipeline)
MongoDB聚合管道 使用聚合管道可以对集合中的文档进行变换和组合. 管道是由一个个功能节点组成的,这些节点用管道操作符来进行表示.聚合管道以一个集合中的所有文档作为开始,然后这些文档从一个操作节点 ...
- MongoDB学习笔记——聚合操作之MapReduce
MapReduce MongoDB中的MapReduce相当于关系数据库中的group by.使用MapReduce要实现两个函数Map和Reduce函数.Map函数调用emit(key,value) ...
- MongoDB学习笔记——聚合操作之group,distinct,count
单独的聚合命令(group,distinct,count) 单独聚合命令 比aggregate性能低,比Map-reduce灵活度低:但是可以节省几行javascript代码,后面那句话我自己加的,哈 ...
- mongoDB与sql聚合操作对应图
SQL Terms, Functions, and Concepts MongoDB Aggregation Operators WHERE $match GROUP BY $group HAVING ...
- MongoDB入门三步曲2--基本操作(续)--聚合、索引、游标及mapReduce
mongodb 基本操作(续)--聚合.索引.游标及mapReduce 目录 聚合操作 MapReduce 游标 索引 聚合操作 像大多关系数据库一样,Mongodb也提供了聚合操作,这里仅列取常见到 ...
- MongoDB的聚合操作以及与Python的交互
上一篇主要介绍了MongoDB的基本操作,包括创建.插入.保存.更新和查询等,链接为MongoDB基本操作. 在本文中主要介绍MongoDB的聚合以及与Python的交互. MongoDB聚合 什么是 ...
- MongoDB 聚合操作
在MongoDB中,有两种方式计算聚合:Pipeline 和 MapReduce.Pipeline查询速度快于MapReduce,但是MapReduce的强大之处在于能够在多台Server上并行执行复 ...
- MongoDB之三(高级操作 聚合、游标)
一: 聚合 常见的聚合操作跟sql server一样,有:count,distinct,group,mapReduce. <1> count count是最简单,最容易,也是最常用的聚合工 ...
随机推荐
- [Swift]LeetCode814. 二叉树剪枝 | Binary Tree Pruning
We are given the head node root of a binary tree, where additionally every node's value is either a ...
- iFace安全专家揭秘:存放在区块链钱包中的比特币,其实已经早就不属于你……
自MoreToken钱包跑路之后,2019年3月以来陆续多个钱包.交易所跑路,造成了大量用户账户被盗,仅MoreToken钱包用户损失总价值就达12.2亿人民币,用户损失惨重.为什么这么多钱包.交易所 ...
- js使用面向对象编写下拉菜单
<html> <head> <meta http-equiv="Content-Type" content="text/html; char ...
- Android Studio gradle插件版本和gradle版本对应关系
1.gradle插件版本配置位置: project对应的build.gradle文件中 buildscript { repositories { jcenter() } dependencies { ...
- SpringBoot入门教程(五)Java基于MySQL实现附近的人
“附近的人”这个功能估计都不陌生,与之类似的功能最开始是在各大地图应用上接触过,比如搜附近的电影院,附近的超市等等.然而真正让附近的人火遍大江南北的应该是微信"附近的人"这个功能, ...
- CentOs~程序部署那些事
永久更新中…… 主要说一下在centos里,在安装程序和监控程序时,用到的一些常用的命令,希望可以帮到大家! 远程安装程序包:yum install 程序包名 下载程序包:wget 程序包地址 解压t ...
- java~spring-ioc的使用
spring-ioc的使用 IOC容器在很多框架里都在使用,而在spring里它被应用的最大广泛,在框架层面 上,很多功能都使用了ioc技术,下面我们看一下ioc的使用方法. 把服务注册到ioc容器 ...
- 汇编实现: C库常见函数,串操作指令作用
目录 汇编实现: C库常见函数 一丶汇编实现Strncpy拷贝函数 二丶loads实现Strlen操作. 三丶stos的作用 汇编实现: C库常见函数 一丶汇编实现Strncpy拷贝函数 void _ ...
- github总结(4)--关于git reset --hard这个命令的惨痛教训
背景叙述: 前几天,上传自己的个站到git上的时候,手欠脑发晕的用了次git reset --hard xxxxxx 命令.由于只在线上传入了一个index.html页面(自己都不知道自己咋想的,就这 ...
- 原型模式 prototype 创建型 设计模式(七)
原型模式 prototype 意图 用原型实例指定需要创建的对象的类型,然后使用复制这个原型对象的方法创建出更多同类型的对象 显然,原型模式就是给出一个对象,然后克隆一个或者更多个对象 小时候看 ...