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

本文涉及的产品
云数据库 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
相关文章
|
5月前
|
DataWorks NoSQL fastjson
DataWorks操作报错合集之DataX进行MongoDB全量迁移的过程中,DataX的MongoDB Reader插件在初始化阶段找不到Fastjson 2.x版本的类库,该怎么办
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
6月前
|
存储 NoSQL Linux
【MongoDB】下载安装、指令操作
【MongoDB】下载安装、指令操作
197 1
|
6月前
|
分布式计算 DataWorks NoSQL
DataWorks操作报错合集之从MongoDB同步数据到MaxCompute(ODPS)时,出现报错,该怎么解决
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
DataWorks操作报错合集之从MongoDB同步数据到MaxCompute(ODPS)时,出现报错,该怎么解决
|
6月前
|
NoSQL Shell MongoDB
python操作MongoDB部分
python操作MongoDB部分
40 0
|
6月前
|
NoSQL BI MongoDB
MongoDB 数据探索之道:查询文档操作详解
MongoDB 数据探索之道:查询文档操作详解
|
6月前
|
NoSQL 安全 MongoDB
MongoDB 数据精简指南:删除文档操作详解
MongoDB 数据精简指南:删除文档操作详解
|
6月前
|
NoSQL JavaScript 安全
精心操作MongoDB:删除数据库的关键步骤和重要事项
精心操作MongoDB:删除数据库的关键步骤和重要事项
186 0
|
19天前
|
算法
你对Collection中Set、List、Map理解?
你对Collection中Set、List、Map理解?
53 18
你对Collection中Set、List、Map理解?
|
12天前
|
存储 缓存 安全
只会“有序无序”?面试官嫌弃的List、Set、Map回答!
小米,一位热衷于技术分享的程序员,通过与朋友小林的对话,详细解析了Java面试中常见的List、Set、Map三者之间的区别,不仅涵盖了它们的基本特性,还深入探讨了各自的实现原理及应用场景,帮助面试者更好地准备相关问题。
49 20
|
29天前
|
存储 C++ 容器
【C++】map、set基本用法
本文介绍了C++ STL中的`map`和`set`两种关联容器。`map`用于存储键值对,每个键唯一;而`set`存储唯一元素,不包含值。两者均基于红黑树实现,支持高效的查找、插入和删除操作。文中详细列举了它们的构造方法、迭代器、容量检查、元素修改等常用接口,并简要对比了`map`与`set`的主要差异。此外,还介绍了允许重复元素的`multiset`和`multimap`。
30 3
【C++】map、set基本用法