MongoDB内嵌文档操作
2022/2/11 19:16:39
本文主要是介绍MongoDB内嵌文档操作,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
嵌套数组更新
以下面的数据(数据集名称为author)为例:
1 |
{name: '岛上码农' , documents: [ 'Flutter入门与实战' , '高性能MySQL' , 'MongoDB专业指北' ]}
|
我们需要将 MongoDB专业指北改成MongoDB不专业指北,就属于修改嵌套的文档数据了。这个时候需要使用到 MongoDB 提供的定位操作符$。定位操作符即表示将对应条件匹配到的数据,如:
1 2 3 4 |
db.author.update(
{name: '岛上码农' , documents: 'MongoDB专业指北' },
{ '$set' : { 'documents.$' : 'MongoDB不专业指北' }}
);
|
对于下级节点为数组的也是一样。
1 2 3 4 5 6 7 8 |
{
name: '岛上码农' ,
documents: [
{name: 'Flutter入门与实战' , score: 80},
{name: '高性能MySQL' , score: 90},
{name: 'MongoDB专业指北' , score: 85}
]
}
|
需要将 documengs 节点的 name 和 score 进行修改。
1 2 3 4 5 6 7 |
db.author.update(
{name: '岛上码农' , 'documents.name' : 'MongoDB专业指北' },
{ '$set' : {
'documents.$.name' : 'MongoDB不专业指北' ,
'documents.$.score' :88}
}
);
|
$定位操作符即在查询条件中找到的数组中的数据元素位置,即表示操作的是该位置的数据。
更新下级文档的属性
更新下级文档属性时可以直接使用属性访问符“.”,例如下面需要更新 praise 增加到291。
1 2 3 4 5 6 7 8 |
{
name: '岛上码农' ,
scores: {
view: 18800,
praise: 290,
followers: 105
}
}
|
1 2 3 4 |
db.author.update(
{name: '岛上码农' },
{ '$set' : { 'scores.praise' : 291}}
);
|
下级文档若还存在嵌套数组也是类似的操作,如下面的数据,需要将“公众号”换成“微信公众号”:
1 2 3 4 5 6 7 8 9 |
{
name: '岛上码农' ,
scores: {
view: 18800,
praise: 290,
followers: 105,
platform: [ '掘金' , '公众号' ]
}
}
|
1 2 3 4 |
db.author.update(
{ 'name' : '岛上码农' , 'scores.platform' : '公众号' },
{ '$set' : { 'scores.platform.$' : '微信公众号' }}
);
|
属性增加和移除
MongoDB提供了 $push 和 $pull操作指令来增加或移除属性,同时还提供了 $pop 来移除数组的第一个或最后一个值。我们给前一个文档增加一个 homepage 属性。
1 2 3 4 |
db.author.update(
{name: '岛上码农' },
{$push: {homepage: 'https://juejin.cn/user/70787819648695' }}
);
|
注意的是,此时插入的是一个名为 homepage 的数组,其中的一个元素是:juejin.cn/user/707878…。如果是增加不是数组的属性,使用$set 指令即可。 可以使用 pull 移除掉匹配的一个属性。
1 2 3 4 |
db.author.update(
{name: '岛上码农' },
{$pull: {homepage: 'https://juejin.cn/user/70787819648695' }}
);
|
$pop 操作时使用数字-1和1表示移除首尾的元素,对于下面的数据,移除数组platform里的数据。
1 2 3 4 5 6 7 8 9 |
{
name: '岛上码农' ,
scores : {
view: 18800,
praise: 290,
followers: 105,
platform: [ '掘金' , '公众号' , '其他1' , '其他2' ]
}
}
|
1 2 3 4 |
// 移除第一个元素
db.author.update({name: '岛上码农' }, {$pop: { 'scores.platform' : -1}});
// 移除最后一个元素
db.author.update({name: '岛上码农' }, {$pop: { 'scores.platform' : 1}});
|
这篇关于MongoDB内嵌文档操作的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-15SendGrid 的 Go 客户端库怎么实现同时向多个邮箱发送邮件?-icode9专业技术文章分享
- 2024-11-15SendGrid 的 Go 客户端库怎么设置header 和 标签tag 呢?-icode9专业技术文章分享
- 2024-11-12Cargo deny安装指路
- 2024-11-02MongoDB项目实战:从入门到初级应用
- 2024-11-01随时随地一键转录,Google Cloud 新模型 Chirp 2 让语音识别更上一层楼
- 2024-10-25Google Cloud动手实验详解:如何在Cloud Run上开发无服务器应用
- 2024-10-24AI ?先驱齐聚 BAAI 2024,发布大规模语言、多模态、具身、生物计算以及 FlagOpen 2.0 等 AI 模型创新成果。
- 2024-10-20goland工具下,如修改一个项目的标准库SDK的版本-icode9专业技术文章分享
- 2024-10-17Go学习:初学者的简单教程
- 2024-10-17Go学习:新手入门完全指南