MongoDB如何更新多級文檔的數(shù)據(jù)
嵌套數(shù)組更新
以下面的數(shù)據(jù)(數(shù)據(jù)集名稱為author)為例:
{name: '島上碼農(nóng)', documents: ['Flutter入門與實(shí)戰(zhàn)', '高性能MySQL', 'MongoDB專業(yè)指北']}
我們需要將 MongoDB專業(yè)指北改成MongoDB不專業(yè)指北,就屬于修改嵌套的文檔數(shù)據(jù)了。這個(gè)時(shí)候需要使用到 MongoDB 提供的定位操作符$。定位操作符即表示將對應(yīng)條件匹配到的數(shù)據(jù),如:
db.author.update(
{name: '島上碼農(nóng)', documents: 'MongoDB專業(yè)指北'},
{'$set': {'documents.$': 'MongoDB不專業(yè)指北'}}
);
對于下級節(jié)點(diǎn)為數(shù)組的也是一樣。
{
name: '島上碼農(nóng)',
documents: [
{name: 'Flutter入門與實(shí)戰(zhàn)', score: 80},
{name: '高性能MySQL', score: 90},
{name: 'MongoDB專業(yè)指北', score: 85}
]
}
需要將 documengs 節(jié)點(diǎn)的 name 和 score 進(jìn)行修改。
db.author.update(
{name: '島上碼農(nóng)', 'documents.name': 'MongoDB專業(yè)指北'},
{'$set': {
'documents.$.name': 'MongoDB不專業(yè)指北',
'documents.$.score':88}
}
);
$定位操作符即在查詢條件中找到的數(shù)組中的數(shù)據(jù)元素位置,即表示操作的是該位置的數(shù)據(jù)。
更新下級文檔的屬性
更新下級文檔屬性時(shí)可以直接使用屬性訪問符“.”,例如下面需要更新 praise 增加到291。
{
name: '島上碼農(nóng)',
scores: {
view: 18800,
praise: 290,
followers: 105
}
}
db.author.update(
{name: '島上碼農(nóng)'},
{'$set': {'scores.praise': 291}}
);
下級文檔若還存在嵌套數(shù)組也是類似的操作,如下面的數(shù)據(jù),需要將“公眾號”換成“微信公眾號”:
{
name: '島上碼農(nóng)',
scores: {
view: 18800,
praise: 290,
followers: 105,
platform: ['掘金', '公眾號']
}
}
db.author.update(
{'name': '島上碼農(nóng)', 'scores.platform': '公眾號'},
{'$set': {'scores.platform.$':'微信公眾號'}}
);
屬性增加和移除
MongoDB提供了 $push 和 $pull操作指令來增加或移除屬性,同時(shí)還提供了 $pop 來移除數(shù)組的第一個(gè)或最后一個(gè)值。我們給前一個(gè)文檔增加一個(gè) homepage 屬性。
db.author.update(
{name: '島上碼農(nóng)'},
{$push: {homepage: 'https://juejin.cn/user/70787819648695'}}
);
注意的是,此時(shí)插入的是一個(gè)名為 homepage 的數(shù)組,其中的一個(gè)元素是:juejin.cn/user/707878…。如果是增加不是數(shù)組的屬性,使用$set 指令即可。 可以使用 pull 移除掉匹配的一個(gè)屬性。
db.author.update(
{name: '島上碼農(nóng)'},
{$pull: {homepage: 'https://juejin.cn/user/70787819648695'}}
);
$pop 操作時(shí)使用數(shù)字-1和1表示移除首尾的元素,對于下面的數(shù)據(jù),移除數(shù)組platform里的數(shù)據(jù)。
{
name: '島上碼農(nóng)',
scores : {
view: 18800,
praise: 290,
followers: 105,
platform: ['掘金', '公眾號', '其他1', '其他2']
}
}
// 移除第一個(gè)元素
db.author.update({name: '島上碼農(nóng)'}, {$pop: {'scores.platform': -1}});
// 移除最后一個(gè)元素
db.author.update({name: '島上碼農(nóng)'}, {$pop: {'scores.platform': 1}});
總結(jié)
本篇介紹了 MongoDB 的嵌套屬性更新操作,主要是定位操作符$的使用。通過定位符可以定位我們需要修改的數(shù)據(jù)位置,進(jìn)而進(jìn)行更新操作。以及屬性的添加和移除,通過$push、$pull和$pop指令即可完成響應(yīng)的操作。
以上就是MongoDB如何更新多級文檔的數(shù)據(jù)的詳細(xì)內(nèi)容,更多關(guān)于MongoDB 更新多級文檔的資料請關(guān)注腳本之家其它相關(guān)文章!
- 分布式文檔存儲數(shù)據(jù)庫之MongoDB訪問控制的操作方法
- 分布式文檔存儲數(shù)據(jù)庫之MongoDB備份與恢復(fù)的實(shí)踐詳解
- 分布式文檔存儲數(shù)據(jù)庫之MongoDB分片集群的問題
- SpringDataMongoDB多文檔事務(wù)的實(shí)現(xiàn)
- mongodb如何對文檔內(nèi)數(shù)組進(jìn)行過濾的方法步驟
- MongoDB中文檔的更新操作示例詳解
- MongoDB數(shù)據(jù)庫文檔操作方法(必看篇)
- mongodb 數(shù)據(jù)類型(null/字符串/數(shù)字/日期/內(nèi)嵌文檔/數(shù)組等)
- PHP庫 查詢Mongodb中的文檔ID的方法
相關(guān)文章
大數(shù)據(jù)環(huán)境下mongoDB為何要加索引淺析
這篇文章主要給大家介紹了關(guān)于大數(shù)據(jù)環(huán)境下mongoDB為何要加索引的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用mongoDB具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
深入分析Mongodb數(shù)據(jù)的導(dǎo)入導(dǎo)出
這幾天想著公司要用MongoDB,自然就要用到數(shù)據(jù)導(dǎo)入導(dǎo)出,就自己學(xué)習(xí)了一下。本文介紹了mongoDb導(dǎo)入導(dǎo)出數(shù)據(jù)的方法,有需要的朋友參考下。2015-05-05
MongoDB4.28開啟權(quán)限認(rèn)證配置用戶密碼登錄功能
這篇文章主要介紹了MongoDB4.28開啟權(quán)限認(rèn)證配置用戶名和密碼認(rèn)證登錄,本文分步驟給大家介紹開啟認(rèn)證登錄的方法,需要的朋友可以參考下2022-01-01
mongodb錯(cuò)誤tcmalloc: large alloc out of memory, printing stack
這篇文章主要介紹了mongodb錯(cuò)誤tcmalloc: large alloc out of memory, printing stack and exiting解決辦法,需要的朋友可以參考下2014-06-06
MongoDB特點(diǎn)與體系結(jié)構(gòu)等簡介
今天小編就為大家分享一篇關(guān)于MongoDB特點(diǎn)與體系結(jié)構(gòu)等簡介,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01

