您的位置:首页 > 编程语言 > Go语言

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

2016-10-10 16:30 190 查看

插入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")


查询到所有文档中不同的名字,相当于给名字去重
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐