`

MongoDB入门3——更新文档和修改器1

阅读更多

    我们前面讲MongoDB的CRUD操作讲过:MongoDB的更新操作通过集合的update()函数实现。这个函数有两个参数:要更改的文档和更改后的样子。要更新文档有两种情况:更新文档和对文档某些部分更新。下面分别说说这两种情况:

    1.更新整个文档

    假设现在有下面的一个文档:

 

{"name":"zhangsan","dad":"zhangyi","mom":"lisi"}; 

    如果觉得这样不好,需要讲父亲和母亲的信息组织到一起,成为一个新的文档:parents,另外,加上一个年龄字段age.那么新的文档如下:

 

{"name":"zhangsan","age":20,"parents":{dad:"zhangyi","mom":"lisi"}}; 

 

    如果要将数据库中的第一个文档替代为上面第二个文档,使用update操作的过程如下:

 

> var zhangsan = db.info.findOne({"name" : "zhangsan"}); 
> zhangsan 
{ 
    "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), 
    "name" : "zhangsan", 
    "dad" : "zhangyi", 
    "mom" : "lisi" 
} 
> zhangsan.parents={"dad":zhangsan.dad,"mom":zhangsan.mom}; 
{ "dad" : "zhangyi", "mom" : "lisi" } 
> zhangsan 
{ 
    "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), 
    "name" : "zhangsan", 
    "dad" : "zhangyi", 
    "mom" : "lisi", 
    "parents" : { 
        "dad" : "zhangyi", 
        "mom" : "lisi" 
    } 
} 
> zhangsan.age=20 
20 
> zhangsan 
{ 
    "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), 
    "name" : "zhangsan", 
    "dad" : "zhangyi", 
    "mom" : "lisi", 
    "parents" : { 
        "dad" : "zhangyi", 
        "mom" : "lisi" 
    }, 
    "age" : 20 
} 
> delete zhangsan.dad 
true 
> zhangsan 
{ 
    "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), 
    "name" : "zhangsan", 
    "mom" : "lisi", 
    "parents" : { 
        "dad" : "zhangyi", 
        "mom" : "lisi" 
    }, 
    "age" : 20 
} 
> delete zhangsan.mom 
true 
> zhangsan 
{ 
    "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), 
    "name" : "zhangsan", 
    "parents" : { 
        "dad" : "zhangyi", 
        "mom" : "lisi" 
    }, 
    "age" : 20 
} 
> db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},zhangsan); 
> db.info.find(); 
{ "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" }, "age" : 20 } 
>  

 

    以这种方式进行文档更新需要注意一点:尽量通过_id来匹配需要被替换的文档。至于为什么,我想用过数据库的人应该都能明白(类似于用主键去匹配特性的记录)。

    2.使用修改器部分修改文档的一部分

    a) $set修改器

    $set修改器指定一个键的新值,若不存在则创建新的。我们要给上面的zhangsan文档(数据库中的)添加一个wife键值对。

> db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},{"$set":{"wife":"wangwu"}}); 
> db.info.find(); 
{ "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "age" : 20, "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" }, "wife" : "wangwu" } 
> 

 

     现在过了一年,张三已经是21岁了,那么可以使用$set更新age键的值:

> db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},{"$set":{"age":21}}); 
> db.info.find(); 
{ "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "age" : 21, "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" }, "wife" : "wangwu" } 
> 

 

     当然这种情况还有别的修改器可以实现,并且更合适,我们一会会继续介。

     zhangsan离婚了,没老婆了,怎们办?我们可以通过$unset修改器来撤销wife这个键值对。(PS:这个例子不是很合适,太残酷了) 

 

> db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},{"$unset":{"wife":1}}); 
> db.info.find(); 
{ "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "age" : 21, "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" } } 
> 

 

 

    b)$inc修改器

    $inc修改器增加和修改已有键的值(只适用于数字类型)。上面我们提到,随着时间推移,zhangsan的年龄会不断增大,就可以使用这个修改器:

 

> db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},{"$inc":{"age":1}}); 
> db.info.find(); 
{ "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "age" : 22, "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" } } 
>  

 

 

    这个修改器非常适合那些投票、计分、访问量统计一类的情况。但是得注意,这个选择器只适用于对数字类型的键值对进行增加和减少。减少只需要传递负值就可以了。

 

0
0
分享到:
评论

相关推荐

    读书笔记:《左手MongoDB右手Redis——从入门到商业实战》书籍配套源代码。.zip

    读书笔记:《左手MongoDB右手Redis——从入门到商业实战》书籍配套源代码。

    MongoDB入门指南.pdf

    3.内容管理:MongoDB可以用于内容管理,可以用于管理大量的文档和媒体文件。 4.移动应用:MongoDB可以用于移动应用,可以用于存储和管理移动应用中的数据。 MongoDB是一种功能强大且灵活的数据库管理系统,可以满足...

    mongoDB的官方中文文档

    MongoDB是一种流行的开源、分布式文档型数据库,以其灵活性、高性能和易用性而备受开发者青睐。作为NoSQL数据库的一种,它存储数据的方式不同于传统的表结构,而是采用键值对、文档、集合的形式。MongoDB的官方中文...

    mongoDB入门到精通.txt

    ### MongoDB入门到精通知识点概述 #### 一、MongoDB简介 MongoDB是一种开源的文档数据库,采用JSON格式存储数据,并提供了高性能、高可用性和自动扩展的能力。它属于NoSQL数据库的一种,非常适合处理大规模数据和...

    mongodb 数据库基本操作.doc

    ### MongoDB数据库基本操作详解 #### 一、连接MongoDB数据库 MongoDB是一个广泛使用的开源文档数据库,支持多种编程语言。...因此,在实际操作中,建议参考MongoDB的官方文档或相关教程以获取更详细和准确的信息。

    MongoDB入门教程 + 架构简析 + java使用MongoDB的简单程序

    MongoDB是一种流行的开源文档数据库系统,它属于NoSQL数据库类别,以其灵活性、可扩展性和高性能而受到广大开发者的青睐。本教程将引导你逐步了解MongoDB的基础知识,深入其架构,并展示如何在Java环境中使用MongoDB...

    MongoDB入门.pdf

    ### MongoDB入门知识点详解 #### 一、NoSQL简介与MongoDB概述 - **NoSQL**:NoSQL(Not Only SQL)是一种非关系型数据库管理系统的总称,它突破了传统关系型数据库在处理大规模数据时的限制,尤其适用于大数据及高...

    MongoDB 入门

    MongoDB是一种流行的开源、分布式文档数据库,用于处理大量的结构化和半结构化数据。作为NoSQL数据库的一员,它提供了一种灵活的数据模型,适合于快速开发和处理大规模数据。在这个“MongoDB入门”主题中,我们将...

    mongodb入门到精通

    根据提供的文件内容,我们将详细探讨MongoDB相关的知识点,并围绕NoSQL数据库的特点和优势,以及分布式系统理论中的CAP定理和ACID与BASE模型。 首先,MongoDB是一种流行的NoSQL数据库,它以文档的形式存储数据,与...

    mongodb入门时候文档

    MongoDB是一款开源、分布式、高性能的NoSQL数据库,特别适合处理海量数据和高并发场景。...在深入学习过程中,官方文档是最好的参考资料,它包含详尽的指南、教程和API文档,对于理解和应用MongoDB至关重要。

    适用于java语言的MongoDB解决方案——Mongernate

    1. 对象映射:Mongernate允许我们将Java对象映射到MongoDB的文档。这样,开发者可以用面向对象的方式处理数据,而不需要直接编写SQL查询或使用低级MongoDB API。 2. 数据持久化:通过Mongernate,可以实现Java对象...

    MongoDB 入门教程 chm手册

    1. **数据模型**:MongoDB 使用类似 JSON 的文档结构(BSON)来存储数据,这种模式允许存储复杂的数据结构,如嵌套文档和数组。与传统关系型数据库中的行和列不同,MongoDB 中的数据是无模式的,这意味着每个文档...

    MongoDB入门学习

    - **更新文档**:使用`update`命令来修改集合中的文档。 - **删除文档**:使用`remove`命令来删除集合中的文档。 #### 五、MongoDB高级特性 - **索引管理**:MongoDB支持多种类型的索引,包括单字段索引、复合索引...

    MongoDB入门到精通

    相比之下,MongoDB 使用的是集合(Collections)和文档(Documents)的概念。这意味着在 MongoDB 中,每个文档都可以有不同的字段和结构,这种灵活性非常适合处理非结构化数据。 例如,在关系型数据库中,为了存储...

    MongoDB入门教程 chm文档

    MongoDB是一个基于分布式文件存储...MongoDB[2]是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。 教程官网:http://www.w3cschool.cc/mongodb/mongodb-tutorial.html

    MongoDB入门到精通 中文资料

    Mongo DB ,是目前在IT行业非常流行的一种非关系型数据库(NoSql),其灵活的数据存储方式,备受当前IT从业人员的青睐。Mongo DB很好的实现了面向对象的思想(OO思想),在Mongo DB中 每一条记录都是一个Document对象。...

    MongoDB配置及应用(文档)

    MongoDB配置及应用(文档) 仅供学习交流! 后续会持续分享相关资源,记得关注哦! MongoDB配置及应用(文档) 仅供学习交流! 后续会持续分享相关资源,记得关注哦! MongoDB配置及应用(文档) 仅供学习交流! ...

    windows 64位mongodb安装包+java api文档

    MongoDB是一款高性能、无模式的分布式文档数据库,广泛应用于现代应用程序开发中,特别是对于处理大量非结构化数据的场景。Windows 64位版本的MongoDB安装包是为64位操作系统设计的,能充分利用系统资源,提供更好的...

Global site tag (gtag.js) - Google Analytics