c)数组修改器
数组修改器,顾名思义,当然是操作数组的啦。一般来说多数组的操作有若干不同种类的,因此,MongoDB也准备了不同的数组修改器。我们会一一学习。
$push修改器能够向指定的数组的末端插入一个新的元素。假设这个数组本身都不存在,那么先创建这个数组。现在假设我现在发表一篇博客,刚一发表,就有人发表评论了。这时候就需要往评论列表中加一个评论记录。
> db.blog.insert({"title":"A New Blog","content":"MongoDB tutorial..."});
> db.blog.update({"title":"A New Blog"},{"$push":{"comments":{"name":"xiaobai","content":"very good"}}});
> db.blog.find();
{ "_id" : ObjectId("4ee47369af9c9fecc9c9cf61"), "comments" : [ { "name" : "xiaobai", "content" : "very good" } ], "content" : "MongoDB tutorial...", "title" : "A New Blog" }
>
之前没记录,但是现在已经添加了一个评论数组,并且已经往里面加入了xiaobai的评论。现在再往里面添加一条评论:
> db.blog.update({"title":"A New Blog"},{"$push":{"comments":{"name":"xiaohong","content":"very very good"}}});
> db.blog.find();
{ "_id" : ObjectId("4ee47369af9c9fecc9c9cf61"), "comments" : [ { "name" : "xiaobai", "content" : "very good" }, { "name" : "xiaohong", "content" : "very very good" } ], "content" : "MongoDB tutorial...", "title" : "A New Blog" }
>
如果有这种情况:一个人只允许只允许评论一次,那么我们在添加新的评论时,就需要判断要添加的评论是否已经存在了。$ne修改器就是判断是否不存在某条记录,不存在的时候才执行某个操作。接着上面的例子,我们先查看,评论中没有lisi的评论的话,我们就插入一条新的lisi的评论:
> db.blog.update({"title":"A New Blog","comments.name":{"$ne":"lisi"}},{"$push":{"comments":{"name":"lisi","comment":"Not Bad"}}});
> db.blog.find();
{ "_id" : ObjectId("4ee47369af9c9fecc9c9cf61"), "comments" : [ { "name" : "xiaobai", "content" : "very good" }, { "name" : "xiaohong", "content" : "very very good" }, { "name" : "lisi", "comment" : "Not Bad" } ], "content" : "MongoDB tutorial...", "title" : "A New Blog" }
>
现在,如果我们再次执行上面的update代码,就不会再添加lisi的评论了。这里我们就不再演示了。
这个修改器其实做的就是上面一样的事情。它会自动的判断某个键是否存在重复的值。不存在才添加记录。现在如果有一个关于用户信息的文档如下:
> var user = {"name":"Tom","emailaddrs":["a@b.com","b@b.com"]};
> db.users.insert(user);
> db.users.find();
{ "_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62"), "name" : "Tom", "emailaddrs" : [ "a@b.com", "b@b.com" ] }
>
现在我们需要再加一个邮件地址:c@b.com,我们可以使用这个修改器添加新的邮件地址:
> db.users.update({"_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62")},{"$addToSet":{"emailaddrs":"c@b.com"}});
> db.users.find();
{ "_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62"), "emailaddrs" : [ "a@b.com", "b@b.com", "c@b.com" ], "name" : "Tom" }
>
再次执行上面的操作是不会重复添加邮件地址的。
- $each修改器(配合$addToSet修改器使用)
$addToSet配合$each修改器可以实现一次批量修改。接着上面邮件列表的例子,如果一次需要添加几个邮件地址,使用$ne和$push就不能一次直接添加多个地址。操作如下:
> db.users.update({"_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62")},{"$addToSet":{"emailaddrs":{"$each":["d@b.com","e@b.com"]}}});
> db.users.find();
{ "_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62"), "emailaddrs" : [ "a@b.com", "b@b.com", "c@b.com", "d@b.com", "e@b.com" ], "name" : "Tom" }
>
$pop修改器
这个修改器可以将数组任何一端的第一个值删除。{"pop":{key:1}}将数组尾部值删掉,{"pop":{key:-1}}:将数组头部值删除。演示一下:
> db.users.update({"_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62")},{"$pop":{"emailaddrs":1}});
> db.users.update({"_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62")},{"$pop":{"emailaddrs":-1}});
> db.users.find();
{ "_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62"), "emailaddrs" : [ "b@b.com", "c@b.com", "d@b.com" ], "name" : "Tom" }
>
这样,第一个和最后一个邮件地址都被删除了。
这个修改器也是用来删除数组中的元素的,但是是通过条件匹配来删除所有条件满足的值,而不仅仅是删某一个。接上面的例子,我们可以用它删除c@b.com
> db.users.update({"_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62")},{"$pull":{"emailaddrs":"c@b.com"}});
> db.users.find();
{ "_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62"), "emailaddrs" : [ "b@b.com", "d@b.com" ], "name" : "Tom" }
>
数组定位修改器
数组定位可以通过两种方式实现:下标和$(定位操作符)。下标是从0开始的。
数组定位方式修改第一个邮件地址:
> db.users.update({"_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62")},{"$set":{"emailaddrs.0":"bbb@b.com"}});
> db.users.find();
{ "_id" : ObjectId("4ee49adeaf9c9fecc9c9cf62"), "emailaddrs" : [ "bbb@b.com", "d@b.com" ], "name" : "Tom" }
>
上面的情况有个不足:不查询出结果怎么知道顺序呢。为了解决这个问题,引入了$定位操作符。用来匹配查询条件查询出来的结果(也就是update的第一个参数)。
回到上面那个评论的例子,我们要修改把评论人为xiaobai的评论的评论人改成xiaoxiaobai。
> db.blog.update({"comments.name":"xiaobai"},{"$set":{"comments.$.name":"xiaoxiaobai"}});
> db.blog.find()
{ "_id" : ObjectId("4ee47369af9c9fecc9c9cf61"), "comments" : [ { "content" : "very good", "name" : "xiaoxiaobai" }, { "name" : "xiaohong", "content" : "very very good" }, { "name" : "lisi", "comment" : "Not Bad" } ], "content" : "MongoDB tutorial...", "title" : "A New Blog" }
>
如果有多条匹配,则只会修改第一条。
上面就是基本的修改器了。
参考书籍:
《MongoDB:The definitive guide》
分享到:
相关推荐
读书笔记:《左手MongoDB右手Redis——从入门到商业实战》书籍配套源代码。
MongoDB入门指南 MongoDB是一种开源的文档类型数据库,它具有高性能、可扩展、高可用、自动收缩等特性。MongoDB能够避免传统的ORM映射,从而有助于开发。MongoDB中的每一行记录就是一个文档,它是一个由键值对构成...
MongoDB是一种流行的开源、分布式文档型数据库,以其灵活性、高性能和易用性而备受开发者青睐。作为NoSQL数据库的一种,它存储数据的方式不同于传统的表结构,而是采用键值对、文档、集合的形式。MongoDB的官方中文...
### MongoDB数据库基本操作详解 #### 一、连接MongoDB数据库 MongoDB是一个广泛使用的开源文档数据库,支持多种编程语言。...因此,在实际操作中,建议参考MongoDB的官方文档或相关教程以获取更详细和准确的信息。
MongoDB是一种流行的开源文档数据库系统,它属于NoSQL数据库类别,以其灵活性、可扩展性和高性能而受到广大开发者的青睐。本教程将引导你逐步了解MongoDB的基础知识,深入其架构,并展示如何在Java环境中使用MongoDB...
4. **更新文档**:使用`updateOne()`或`updateMany()`方法更新文档。 5. **删除文档**:使用`deleteOne()`或`deleteMany()`方法删除文档。 #### 六、MongoDB高级特性 1. **索引**:通过创建索引来加速查询速度。 2...
### MongoDB入门知识点详解 #### 一、NoSQL简介与MongoDB概述 - **NoSQL**:NoSQL(Not Only SQL)是一种非关系型数据库管理系统的总称,它突破了传统关系型数据库在处理大规模数据时的限制,尤其适用于大数据及高...
MongoDB是一种流行的开源、分布式文档数据库,用于处理大量的结构化和半结构化数据。作为NoSQL数据库的一员,它提供了一种灵活的数据模型,适合于快速开发和处理大规模数据。在这个“MongoDB入门”主题中,我们将...
根据提供的文件内容,我们将详细探讨MongoDB相关的知识点,并围绕NoSQL数据库的特点和优势,以及分布式系统理论中的CAP定理和ACID与BASE模型。 首先,MongoDB是一种流行的NoSQL数据库,它以文档的形式存储数据,与...
MongoDB是一款开源、分布式、高性能的NoSQL数据库,特别适合处理海量数据和高并发场景。...在深入学习过程中,官方文档是最好的参考资料,它包含详尽的指南、教程和API文档,对于理解和应用MongoDB至关重要。
MongoDB是一种流行的开源文档数据库,它以JSON格式存储数据,非常适合处理半结构化或非结构化数据。在Java开发环境中,为了与MongoDB进行交互,通常会使用到各种驱动程序和框架,其中Mongernate就是一个这样的解决...
### MongoDB PDF帮助手册知识点概述...- **Version Numbers**:解释了MongoDB版本号的命名规则和版本更新策略。 - **Server-Side Processing**:讨论了在服务器端执行处理逻辑的方法和技巧,有助于提升应用的整体性能。
- **更新文档**:使用`update`命令来修改集合中的文档。 - **删除文档**:使用`remove`命令来删除集合中的文档。 #### 五、MongoDB高级特性 - **索引管理**:MongoDB支持多种类型的索引,包括单字段索引、复合索引...
相比之下,MongoDB 使用的是集合(Collections)和文档(Documents)的概念。这意味着在 MongoDB 中,每个文档都可以有不同的字段和结构,这种灵活性非常适合处理非结构化数据。 例如,在关系型数据库中,为了存储...
MongoDB配置及应用(文档) 仅供学习交流! 后续会持续分享相关资源,记得关注哦! MongoDB配置及应用(文档) 仅供学习交流! 后续会持续分享相关资源,记得关注哦! MongoDB配置及应用(文档) 仅供学习交流! ...
Mongo DB ,是目前在IT行业非常流行的一种非关系型数据库(NoSql),其灵活的数据存储方式,备受当前IT从业人员的青睐。Mongo DB很好的实现了面向对象的思想(OO思想),在Mongo DB中 每一条记录都是一个Document对象。...
MongoDB是一个基于分布式文件存储...MongoDB[2]是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。 教程官网:http://www.w3cschool.cc/mongodb/mongodb-tutorial.html
MongoDB是一款高性能、无模式的分布式文档数据库,广泛应用于现代应用程序开发中,特别是对于处理大量非结构化数据的场景。Windows 64位版本的MongoDB安装包是为64位操作系统设计的,能充分利用系统资源,提供更好的...
2. **集合与文档**:在 MongoDB 中,数据存储在集合(Collections)中,集合类似于 RDBMS 的表,但不需要预先定义架构。文档(Documents)是集合中的基本单位,它们是键值对的集合,每个键都有一个唯一的字符串...