MongoDB修改文档

一、文档替换

    文档替换其实在之前已经有讲过了,就是传入两个对象,第一个对象作为调节,第二个条件作为满足条件的文档修改的内容,例如:

    db.test.update({"name":"kevin-01"} , {"name": "kevin"});   # 修改  前面条件为,后面为修改的属性和值

二、修改器进行修改

    文档提交比较好理解,而修改器是在后面一个文档为对象的基础上,将对象的根key作为修改器类型,后面的对象为真正修改操作的对象,如: {"$set": {} }

1、$set $unset

    db.test.update({"name":"kevin-01", {"$set":{"age":NumberInt("18")}}}); # 满足条件:修改年龄字段,没有年龄字段则进行添加

    db.test.update({"name":"kevin-01"},{"$unset":{"age": 1 }});               # 满足条件:删除age字段

2、$inc(减少值可以用负数)

    db.test.update("name":"kevin-01",{"$inc":{"age": 5}});  # 满足条件,年龄加5岁(负数表示减去

3、$push ($each、$slice、 $sort)

    1)、 往数组对象中添加一个元素

    db.test.update({"name":"kevin-01"},{"$push":{"comments":{"id":"1","content":"content-01"}}});

 

    2)、往数组中添加多个元素,使用$each

    commentsArr = [{"id":NumberInt("2","content":"content-02")},{"id":NumberInt("3","content":"content-03")}];

    db.test.update("name":"kevin-01",{"$push":{"$each": commentsArr }});

    3)、往数组中添加多个元素,并进行排序($sort,值为1表示正序,-1反之),只保留最近的多少个元素($slice,值只能为负数)

    commentsArr = [{"id":NumberInt("2","content":"content-02")},{"id":NumberInt("3","content":"content-03")}];

    db.test.update(user, {"$push":{"comments":
           {"$each":[{"id":NumberInt("2"),"content":"content-02"},{"id":NumberInt("3"),"content":"content-03"}],
            "$slice":-2,
            "$sort":{"id":-1}

    }}});

4、$addToSet

    往数组中添加的数据,为了保证不重复,则可以使用$addToSet,并且可以配置$each进行使用,就想配合$push一样:

    db.test.update({"name":"kevin-01"},{"$addToSet":{"email":"[email protected]"}});

    db.test.update({"name":"kevin-01"},{"$addToSet":{"email":{"$each":["[email protected]","[email protected]"]}}});

5、$pop、$pull

    1)、从数组的尾部或者头部删除一个元素, 1表示重尾部删除,-1表示从头部删除

    db.test.update({"name":"kevin-01"},{"$pop":{"email":1}});

    2)、从数组中删除满足条件的元素

    db.test.update({"name":"kevin-01"},{"$pull":{"email":"[email protected]"}});

三、upsert(添加或更新文档)

    1)、upinsert

    # 更新的时候,第一个对象为条件,第二个对象为修改的内容,第三个为true,表示新增或修改

    db.test.update({"name":"kevin-01"},{"classNo":NumberInt("5")},true); 

    2)、$setOnInsert

    # 只保证文档在插入时生效,修改时候则保持不变,如创建时间(createdAt)字段,这也是阿里手册规范

    db.test.update({"name":"kevin-01",{"$setOnInsert":{"createdAt":new Date()}}, true});

    3)、save(方便操作,直接见下图)

三、更新多个文档

    update的第一个参数对象为条件,第二个参数对象为更新的对象,第三个为是否upinsert,第四个为是否修改所有满足条件的所有文档,默认关闭,只修改满足条件的第一条

    db.test.update({条件},{修改},false, true);

猜你喜欢

转载自blog.csdn.net/it_lihongmin/article/details/81410707