【MongoDB学习笔记8】深入MongoDB的更新(update)操作:修改器$set

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:

MongoDB中文档存入数据库后用update方法更新文档,update方法有两个参数,例如

update(args1,args2)

args1是指查询文档的条件;

args2是指对查询到的文档进行什么样的修改;

 

一、文档替换

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
> joe1= db.post.findOne({ "age" :20})
{
         "_id" 
ObjectId( "54a530c3ff0df3732bac1680" ),
         "id"  : 1,
         "name" 
"joe" ,
         "age"  : 20
}
> joe1.age=21
21
db.post.update({ "id" :1},joe1)
WriteResult({  "nMatched"  : 1,  "nUpserted"  : 0, 
"nModified"  : 1 })
>

修改后的结果:

1
2
3
4
5
6
7
8
9
10
> joe1= db.post.findOne({ "age" :21})
{
         "_id" 
ObjectId( "54a530c3ff0df3732bac1680" ),
         "id"  : 1,
         "name" 
"joe" ,
         "age"  : 21
}
>

 

二、使用修改器

1.$set修改器

$set用来指定一个字段的值,如果字段不存在就创建;

1
2
3
4
5
6
7
> db.post.findOne()   
{    
         "_id"  : ObjectId( "54a530c3ff0df3732bac167f" ),    
         "id"  : 0,    
         "name"  "joe" ,    
         "age"  : 65    
}

增加comments的键:   

1
2
3
4
5
6
7
8
9
10
11
12
> db.post.update({ "id" :0},    
... {$ set :{ "comments" : "i love you" }})    
WriteResult({  "nMatched"  : 1,  "nUpserted"  : 0,  "nModified"  : 1 })    
> db.post.findOne()    
{    
         "_id"  : ObjectId( "54a530c3ff0df3732bac167f" ),    
         "id"  : 0,    
         "name"  "joe" ,    
         "age"  : 65,    
         "comments"  "i love you"    
}    
>

修改comments键的值:

1
2
3
4
5
6
7
8
9
10
11
> db.post.update({ "id" :0}, {$ set :{ "comments" : "i don't love you" }})   
WriteResult({  "nMatched"  : 1,  "nUpserted"  : 0,  "nModified"  : 1 })    
> db.post.findOne()    
{    
         "_id"  : ObjectId( "54a530c3ff0df3732bac167f" ),    
         "id"  : 0,    
         "name"  "joe" ,    
         "age"  : 65,    
         "comments"  "i don't love you"    
}    
>

   
修改comments的值为数组:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
> db.post.update({ "id" :0}, {$ set :{ "comments" :[ "i love you" , "or" , "i don't love you" ]}})   
WriteResult({  "nMatched"  : 1,  "nUpserted"  : 0,  "nModified"  : 1 })    
> db.post.findOne({ "id" :0})    
{    
         "_id"  : ObjectId( "54a530c3ff0df3732bac167f" ),    
         "id"  : 0,    
         "name"  "joe" ,    
         "age"  : 65,    
         "comments"  : [    
                 "i love you" ,    
                 "or" ,    
                 "i don't love you"    
         ]    
}    
>

   
删除comments的值:

1
2
3
4
5
6
7
8
9
10
> db.post.update({ "id" :0}, {$ unset :{ "comments" :1}})   
WriteResult({  "nMatched"  : 1,  "nUpserted"  : 0,  "nModified"  : 1 })    
> db.post.findOne({ "id" :0})    
{    
         "_id"  : ObjectId( "54a530c3ff0df3732bac167f" ),    
         "id"  : 0,    
         "name"  "joe" ,    
         "age"  : 65    
}    
>

   

2.修改内嵌文档    

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
> db.post.findOne({ "id" :0})    
{    
         "_id"  : ObjectId( "54a530c3ff0df3732bac167f" ),    
         "id"  : 0,    
         "name"  "joe" ,    
         "age"  : 65,    
         "comments"  : {    
                 "1"  : 1,    
                 "2"  : 2,    
                 "3"  : 3    
         }    
}    
> db.post.update({ "id" :0}, {$ set :{ "comments.1" :4}})    
WriteResult({  "nMatched"  : 1,  "nUpserted"  : 0,  "nModified"  : 1 })    
> db.post.findOne({ "id" :0})    
{    
         "_id"  : ObjectId( "54a530c3ff0df3732bac167f" ),    
         "id"  : 0,    
         "name"  "joe" ,    
         "age"  : 65,    
         "comments"  : {    
                 "1"  : 4,    
                 "2"  : 2,    
                 "3"  : 3    
         }    
}    
>




本文转自 bannerpei 51CTO博客,原文链接:http://blog.51cto.com/281816327/1598398,如需转载请自行联系原作者
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
16天前
|
存储 NoSQL Linux
【MongoDB】下载安装、指令操作
【MongoDB】下载安装、指令操作
61 1
|
18天前
|
分布式计算 DataWorks NoSQL
DataWorks操作报错合集之从MongoDB同步数据到MaxCompute(ODPS)时,出现报错,该怎么解决
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
DataWorks操作报错合集之从MongoDB同步数据到MaxCompute(ODPS)时,出现报错,该怎么解决
|
21天前
|
存储 NoSQL 数据挖掘
深入探索MongoDB聚合操作:解析数据之美
深入探索MongoDB聚合操作:解析数据之美
|
3天前
|
存储 C++ 容器
【C++】学习笔记——map和set
【C++】学习笔记——map和set
7 0
|
4天前
|
NoSQL Shell MongoDB
python操作MongoDB部分
python操作MongoDB部分
|
21天前
|
NoSQL BI MongoDB
MongoDB 数据探索之道:查询文档操作详解
MongoDB 数据探索之道:查询文档操作详解
|
21天前
|
NoSQL 安全 MongoDB
MongoDB 数据精简指南:删除文档操作详解
MongoDB 数据精简指南:删除文档操作详解
|
21天前
|
NoSQL JavaScript 安全
精心操作MongoDB:删除数据库的关键步骤和重要事项
精心操作MongoDB:删除数据库的关键步骤和重要事项
|
3天前
|
Dart
Dart之集合详解(List、Set、Map)
Dart之集合详解(List、Set、Map)
9 1
|
8天前
|
存储 JavaScript 前端开发
JavaScript进阶-Map与Set集合
【6月更文挑战第20天】JavaScript的ES6引入了`Map`和`Set`,它们是高效处理集合数据的工具。`Map`允许任何类型的键,提供唯一键值对;`Set`存储唯一值。使用`Map`时,注意键可以非字符串,用`has`检查键存在。`Set`常用于数组去重,如`[...new Set(array)]`。了解它们的高级应用,如结构转换和高效查询,能提升代码质量。别忘了`WeakMap`用于弱引用键,防止内存泄漏。实践使用以加深理解。