mongo 的crud操作&&mongo的数据聚合

本文介绍MongoDB的基本操作,包括插入、查询、删除及更新文档等。涵盖了常用的命令如insert、find、remove、update等,并详细解释了各种操作符的用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

插入insert

插入单个文档

db.getCollection('users').insert({"name":"sasa"})

插入多个文档

db.getCollection('users').insert([{"name":"sasa"},{"sdsd":"sasa"}])

查询操作query

db.collection.find( , )
用于查找满足过滤条件的Document
(投影)用于指定被找到的Document中需要返回哪些字段,用于限制网络中传输的数据的大小。投影的概念和关系数据库中的投影的概念基本是一致的。
得到users的所有的文档

db.getCollection('users').find()

查找sdsd的值为sasa的文档

db.getCollection('users').find({sdsd:"sasa"})

查找name的值为sasa和sasa1 的文档 $in

db.getCollection('users').find({name:{"$in":["sasa","sasa1"]}})

只显示name、time字段

db.getCollection('posts').find({},{name:1,time:1})

删除操作remove

db.getCollection('users').remove({name:"sasa"},{w:1})

更新操作update

$inc
用法:{ $inc : { field : value } }意思对一个数字字段field增加value 只支持数据类型

db.getCollection('users').update({name:"sasa"},{$inc:{post:1}})

$set
用法:{ set : { field : value } }就是相当于sql的set field = value,全部数据类型都支持set

db.getCollection('users').update({sdsd:"sasa"},{$set:{sdsd:"sasa1"}})

$unset
用法:{ $unset : { field : 1} }顾名思义,就是删除字段了。实现的是删除一特定的字段

db.getCollection('users').update({"name":"sasa1"},{$unset:{"post":1}})

$push
用法:{ $push : { field : value } }把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去。

db.getCollection('users').update({name:"sasa1"},{$push:{grade:1}})

第一次执行的时候会在name为”sasa1”的文档中新增加一个名字为grade的数组,并有有一个元素为1,
第二次执行的时候会在name为”sasa1”的文档中的数组grade增加一个元素。
$pushAll
用法:{ pushAll : { field : value_array } }同push,只是一次可以追加多个值到一个数组字段内。例:

db.getCollection('users').update({name:"sasa1"},{$pushAll:{grade:[2,3,4]}})

$addToset
用法:{ $addToSet : { field : value } }增加一个值到数组内,而且只有当这个值不在数组内才增加。

db.getCollection('users').update({name:"sasa1"},{$addToSet:{grade:[11,3]}})

会在grade这个数组里边新 增加一个新的数组,数组里边会有11和3这两个元素
$pop
删除数组内的一个值
用法:
删除最后一个值:{ pop : { field : 1 } }  
删除第一个值:{
pop : { field : -1 } }

db.getCollection('users').update({name:"sasa1"},{$pop:{grade:1}})

实现的是删除了刚才在grade中最后的新增加的那个数组
$pull
用法:$pull : { field : value } }从数组field内删除一个等于value值。

db.getCollection('users').update({name:"sasa1"},{$pull:{grade:4}})

会删除garde中的值为4 的所有元素
$pullAll
用法:{ pullAll : { field : value_array } }同pull,可以一次删除数组内的多个值。

db.getCollection('users').update({name:"sasa1"},{$pullAll:{grade:[3,4]}})

会删除grade中的所有的3和4

collection.count()

(1)count
作用:简单统计集合中符合某种条件的文档数量。
使用方式:db.collection.count()或者db.collection.find().count()
参数说明:其中是用于查询的目标条件。如果出了想限定查出来的最大文档数,或者想统计后跳过指定条数的文档,则还需要借助于limit,skip。
举例:
db.collection.find().limit();
db.collection.find().skip();

db.getCollection('users').find().skip(2)

(2)distinct
作用:用于对集合中的文档针进行去重处理
使用方式:db,collection.distinct(field,query)
参数说明:field是去重字段,可以是单个的字段名,也可以是嵌套的字段名;query是查询条件,可以为空;
举例:
db.collection.distinct(“user”,{“age”:{$gt:28}});//用于查询年龄age大于28岁的不同用户名

db.getCollection('posts').distinct("name")

查询到所有文档中不同的名字,相当于给名字去重

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值