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

  • 相关阅读:
    AJAX POST请求中参数以form data和request payload形式在servlet中的获取方式
    java如何得到GET和POST请求URL和参数列表
    Tomcat处理HTTP请求源码分析(下)
    Tomcat处理HTTP请求源码分析(上)(转)
    tomcat免重启随意更改java代码 提高开发效率
    ServletRequest中getReader()和getInputStream()只能调用一次的解决办法
    Spring MVC之@RequestParam @RequestBody @RequestHeader 等详解
    Tomcat处理HTTP请求源码分析(上)
    Drupal views中实现两列布局
    (转) 转换Drupal7模块到Drupal8
  • 原文地址:https://www.cnblogs.com/duanjt/p/10341686.html
Copyright © 2011-2022 走看看