mongodb 学习笔记 2 --- 修改器

时间:2022-01-15 02:06:20

修改器是为了爱update文档时,不需要传入整个文档就能修改当前文档的某个属性值,修改器用法如下:

假设数据库中foo集合中存在如下文档:{"name":"jack","age":18}

db.foo.update({"name":"jack"},{"$inc":{"age":2}});  //这是一个修改器用法举例

则更新后的文档变为:{"name":"jack","age":20}

下面将介绍如下修改器

1.$set : 用来指定一个字段的值,如果该字段不存在则创建它。修改内嵌文档时支持 {"$set":{"author.name":"jack"}}的写法,即使author字段不存在也可以;

2.$unset: 用来删除一个字段,使用方法如下:db.foo.update({"name":"jack"},{"$unset":{"age":0}})   不管unset的键值对中值为false 还是为0、null,只要写了就会删除;

3.$inc:用来增加/减少已有键值,如果该键不存在就创建一个;只能增加数字值。数字值的字符串也不行。相应的减少传负值就可以了;

4.$push: 用来向数组中push一条数据,如果该数组不存在则创建。

             子操作符: $each 子操作符配合使用,如 {"$push":{"list":{"$each":[1,2,3]}}} , push后的数据为:{"list":[1,2,3]}   如果不用$each,则变为 {"list":[[1,2,3]]} 

                             $slice  限制push数组的长度,负数从后往前数,正数从前往后数,如{"$push":{"list":{"$each":[1,2,3],"$slice":-2}}},数据变为 {"list":[2,3]} 。 如原有数据{"list":[[1,2,3]]} ,此时{"$push":{"list":{"$each":[4,5,6],"$slice":-2}}},变为{"list":[[5,6]]},可见数据的截取范围是根据整体数据数组而言的

                             $sort   根据排序规则进行数组排序,-1 为降序,1为升序

以上的$slice 和 $sort必须和$push $each共同使用 

5.$ne : not equal ,在筛选条件时表示属性值不等于、或不包含该值,可用于update及find  如 db.foo.find({"list":{"$ne":2}})

6.$addToSet: 在向数组中push值时可以避免重复,用法和$push 相同,不过子操作符只能用$each

7.$pop: 从数组中删除一个元素, {"$pop":{"list":1}}  从后往前删除, {"$pop":{"list":-1}} 从前往后删除  无论list后面这个值传的几,都只删除1个

8.$pull: 从数组中删除指定的值 {"$pull":{"list":2}}  如果里面的相同的值有多个,则都删除

9.$:数组下标占位符,使用方法:比如元数据为 {comments:[{name:"jim",votes:0},{name:'mary',votes:1}]}  进行如下更新操作:db.foo.update({"comments.name":"mary"},{"$set":{"commnets.$.votes":3}})  如匹配条件有多个,只更新第一个