MongoDB基本操作(包括插入、修改、子节点排序等)

一、基本操作

1.新增文章

db.article.insert({title:"今天天气很好",content:"我们一起去春游",_id:1})

 2.新增一条评论

db.article.update({_id:1},{"$set":{comments:[{user:"duanjt",time:new Date("2019-01-30")}]}})

 说明:$set表示替换comments节点的内容

3.再增加四条评论

db.article.update({_id:1},{"$addToSet":{comments:{"$each":[{user:"zhuzhu",time:new Date("2019-01-31")}]}}});
db.article.update({_id:1},{"$addToSet":{comments:{"$each":
[
    {user:"lisi",time:new Date("2019-01-20")},
    {user:"wangwu",time:new Date("2019-01-11")},
    {user:"taoge",time:new Date("2019-01-12")}
]
}}});
db.article.update({_id:1},{"$push":{comments:{"$each":[{user:"chaoling",time:new Date("2019-01-31")}]}}});

 说明:$addToSet表示在节点comments中增加内容。而$each表示将后面指定的数组一个一个插入到comments节点里面。

在这里addToSet和push感觉作用是一样的。

4.查询前2条评论

db.article.find({_id:1},{"comments":{"$slice":[0,2]}});

5.将评论里面用户是“wangwu”的修改为“王五”

db.article.update(
    {"_id":1,"comments.user":"wangwu"},
    {"$set":{"comments.$.user":"王五"}}
)

注意:comments.$.user中的$是一个占位,表示当前匹配的数据行

6.将comments里面的内容按时间或名称排序

db.article.update({_id:1},{"$push":{comments:{"$each":[],"$sort":{"time":1}}}});
db.article.update({_id:1},{"$push":{comments:{"$each":[],"$sort":{"user":1}}}});

 说明:由于MongoDB不提供针对子节点的直接排序方法,所以我们只能通过变通的方式,插入一个空数组,然后再排序。排序完了之后再通过第四步的方法获取数据。


二、关于push和addToSet的区别

db.user.insert({_id:1,name:"段江涛",likes:["学习","劳动"]});    //插入数据,爱好是学习和劳动
db.user.update({_id:1},{"$push":{"likes":{"$each":["学习"]}}});    //通过push增加一个“学习”的爱好,能新增成功
db.user.update({_id:1},{"$addToSet":{"likes":{"$each":["学习"]}}});    //通过addToSet增加一个“学习”的爱好,操作不报错,但是不会新增成功。

 结论:push直接插入,而addToSet会自动排除重复的数据。此外push支持$sort $position $slice,可以控制插入元素的位置、排序和限制元素数量

原文地址:https://www.cnblogs.com/duanjt/p/10341686.html