【MongoDB学习笔记12】深入MongoDB的更新(update)操作:数组修改
admin
2023-04-12 12:02:26
0

查看一个文档的一个键值comments为一个数组[“test1”,”test2”]:

> db.post.findOne({"id":1})   
{    
    "_id" : ObjectId("54a530c3ff0df3732bac1680"),    
    "id" : 1,    
    "name" : "joe",    
    "age" : 21,    
    "comments" : [    
        "test1",    
        "test2"    
    ]    
}    
>

 

一、$push向数组末尾添加元素

> db.post.update({"id":1},{$push:{"comments": "test3"}})   
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })    
> db.post.findOne({"id":1})    
{    
    "_id" : ObjectId("54a530c3ff0df3732bac1680"),    
    "id" : 1,    
    "name" : "joe",    
    "age" : 21,    
    "comments" : [    
        "test1",    
        "test2",    
        "test3"    
    ]    
}    
>

   

使用$each一次性添加多个值:

> db.post.update({"id":1},{$push:{"comments":{$each:["test4","test5","test6"]}}})   
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })    
> db.post.findOne({"id":1})    
{    
    "_id" : ObjectId("54a530c3ff0df3732bac1680"),    
    "id" : 1,    
    "name" : "joe",    
    "age" : 21,    
    "comments" : [    
        "test1",    
        "test2",    
        "test3",    
        "test4",    
        "test5",    
        "test6"    
    ]    
}    
>

二、用$pop删除数组中的元素

从数组末尾删除一个值:

> db.post.update({"id":1},{$pop:{"comments":1}})   
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })    
> db.post.findOne({"id":1})    
{    
    "_id" : ObjectId("54a530c3ff0df3732bac1680"),    
    "id" : 1,    
    "name" : "joe",    
    "age" : 21,    
    "comments" : [    
        "test1",    
        "test2",    
        "test3",    
        "test4",    
        "test5"    
    ]    
}

从数组开头删除一个值:  

> db.post.update({"id":1},{$pop:{"comments":-1}})    
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })    
> db.post.findOne({"id":1})    
{    
    "_id" : ObjectId("54a530c3ff0df3732bac1680"),    
    "id" : 1,    
    "name" : "joe",    
    "age" : 21,    
    "comments" : [    
        "test2",    
        "test3",    
        "test4",    
        "test5"    
    ]    
}    
>

三、删除数组中一个指定的值:

> db.post.update({"id":1},{$pull:{"comments":"test3"}})   
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })    
> db.post.findOne({"id":1})    
{    
    "_id" : ObjectId("54a530c3ff0df3732bac1680"),    
    "id" : 1,    
    "name" : "joe",    
    "age" : 21,    
    "comments" : [    
        "test2",    
        "test4",    
        "test5"    
    ]    
}    
>

四、基于数组下标位置修改:

> db.post.update({"id":1},{$set:{"comments.1":"test9"}})   
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })    
> db.post.findOne({"id":1})    
{    
    "_id" : ObjectId("54a530c3ff0df3732bac1680"),    
    "id" : 1,    
    "name" : "joe",    
    "age" : 21,    
    "comments" : [    
        "test2",    
        "test9",    
        "test5"    
    ]    
}    
>



相关内容

热门资讯

终于懂了“飞鹰牛牛是不是有挂?... 有 亲,根据资深记者爆料飞鹰牛牛是可以开挂的,确实有挂(咨询软件无需打开...
原创 3... 周鸿祎创办的360集团是中国网络安全领域龙头企业,经过20年的发展和积累,已拥有四个“全球领先”优势...
【第一资讯】“17麻将十三水怎... 家人们!今天小编来为大家解答17麻将十三水透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪...
今日重大消息“九酷牛牛怎么开挂... 您好:九酷牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
今日重大消息“微乐锄大地怎么开... 家人们!今天小编来为大家解答微乐锄大地透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买...
今日重大发现“乐游510k是不... 今日重大发现“乐游510k是不是有挂?”(确实真的有挂)您好,乐游510k这个游戏其实有挂的,确实是...
今日重大发现“么么都莱游戏开挂... 您好:么么都莱游戏这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款...
【第一消息】“快乐竞技怎么开挂... 【第一消息】“快乐竞技怎么开挂?”(必胜开挂神器)您好,快乐竞技这个游戏其实有挂的,确实是有挂的,需...
玩家最新攻略“新毛豆互娱开挂器... 有 亲,根据资深记者爆料新毛豆互娱是可以开挂的,确实有挂(咨询软件无需打...
玩家攻略科普“皇豪互娱拼三张开... 家人们!今天小编来为大家解答皇豪互娱拼三张透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪...