设为首页 加入收藏

TOP

MongoDB入门4――更新文档和修改器2 (一)
2014-11-24 07:50:48 来源: 作者: 【 】 浏览:6
Tags:MongoDB 入门 更新 文档 修改器
c)数组修改器


数组修改器,顾名思义,当然是操作数组的啦。一般来说多数组的操作有若干不同种类的,因此,MongoDB也准备了不同的数组修改器。我们会一一学习。

$push修改器
$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" }
>

> 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" }

>

> 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修改器
如果有这种情况:一个人只允许只允许评论一次,那么我们在添加新的评论时,就需要判断要添加的评论是否已经存在了。$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" }
>

> 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的评论了。这里我们就不再演示了。

$addToSet修改器
这个修改器其实做的就是上面一样的事情。它会自动的判断某个键是否存在重复的值。不存在才添加记录。现在如果有一个关于用户信息的文档如下:


> 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" ]
首页 上一页 1 2 3 下一页 尾页 1/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇MongoDB:mongodb的分片技术 下一篇MongoDB入门3――更新文档和修改..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·求navicat for mysql (2025-12-26 13:21:33)
·有哪位大哥推荐一下m (2025-12-26 13:21:30)
·MySQL下载与安装教程 (2025-12-26 13:21:26)
·Linux_百度百科 (2025-12-26 12:51:52)
·Shell 流程控制 | 菜 (2025-12-26 12:51:49)