欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MongoDB 基本操作和聚合操作

程序员文章站 2022-03-13 15:54:47
一 . MongoDB 基本操作 基本操作可以简单分为查询、插入、更新、删除。 1 文档查询 2.文档插入 db.inventory.insertMany([ { item: "journal", qty: 25, tags: ["blank", "red"], size: { h: 14, w: ......

一 . 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  跳过一定数据量的文档