• 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,可以控制插入元素的位置、排序和限制元素数量

  • 相关阅读:
    数据库分库分表(sharding)系列(五) 一种支持自由规划无须数据迁移和修改路由代码的Sharding扩容方案
    数据库分库分表(sharding)系列(三) 关于使用框架还是自主开发以及sharding实现层面的考量
    docker的入门简介
    nginx方向代理详解及配置
    nginx配置文件详解
    nginx安装
    iptables防火墙
    服务器加载过程
    服务器
    操作系统
  • 原文地址:https://www.cnblogs.com/duanjt/p/10341686.html
Copyright © 2020-2023  润新知