• Mongodb学习笔记(2)--修改器


    修改器

    利用原子的更新修改器,可以使得这种部分更新极为高效,更新修改器是一种特殊的键,用来指定复杂的更新操作,比如调整,增加或删除,还可以操作数组或内嵌文档。

    $inc

    $inc修改器用来增加已有键的值,或者键不存在时创建一个键。

    示例文档:

    {"uid":"201203","type":"1",size:10}
    

    运行:

    > db.b.update({"uid" : "201203"},{"$inc":{"size" : 1}})
    > db.b.find()
    { "_id" : ObjectId("5003b6135af21ff428dafbe6"), "uid" : "201203", "type" : "1","size" : 11 }
    

    $set

    用来指定一个键并更新键值,若键不存在并创建。

    示例文档:

    { "_id" : ObjectId("500216de81b954b6161a7d8f"), "desc" : "hello world2!", "num": 40, "sname" : "jk", "type" : "3", "uid" : "20120002" }
    

    键不存在的场合(size):

    > db.a.update({"uid" : "20120002","type" : "3"},{"$set":{"size":10}})
    > db.a.findOne({"uid" : "20120002","type" : "3"})
    { "_id" : ObjectId("500216de81b954b6161a7d8f"), "desc" : "hello world2!", "num": 40, "size" : 10, "sname" : "jk", "type" : "3", "uid" : "20120002" }
    

    键存在的场合(sname):

    > db.a.update({"uid" : "20120002","type" : "3"},{"$set":{"sname":"ssk"}})
    > db.a.find()
    { "_id" : ObjectId("500216de81b954b6161a7d8f"), "desc" : "hello world2!", "num": 40, "size" : 10, "sname" : "ssk", "type" : "3", "uid" : "20120002" }
    

    改变键的值类型:

    > db.a.update({"uid" : "20120002","type" : "3"},{"$set":{"sname":["java",".net","c++"]}})
    > db.a.findOne({"uid" : "20120002","type" : "3"})
    {
            "_id" : ObjectId("500216de81b954b6161a7d8f"),
            "desc" : "hello world2!",
            "num" : 40,
            "size" : 10,
            "sname" : [
                    "java",
                    ".net",
                    "c++"
            ],
            "type" : "3",
            "uid" : "20120002"
    }
    

    修改内嵌文档

    mongodb支持使用语法糖(sup.xx.sub...),修改内嵌文档即使用此方式:

    {"name":"toyota","type":"suv","size":{"height":10,"width":5,"length":15}}
    //使用语法糖来修改内嵌文档
    > db.c.update({"name":"toyota"},{"$set":{"size.height":8}})
    > db.c.findOne({"name":"toyota"})
    {
            "_id" : ObjectId("5003be465af21ff428dafbe7"),
            "name" : "toyota",
            "type" : "suv",
            "size" : {
                    "height" : 8,
                    "width" : 5,
                    "length" : 15
            }
    }
    

    $unset

    主要是用来删除键,示例略。

    数组修改器-- $push

    向已有的数组末尾加入一个元素,若没有则会创建一个新的数组。

    > db.c.find()
    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "type" : "suv", 
    "size" : { "height" : 8, "width" : 7, "length" : 15 } }
    
    --先push一个当前文档中不存在的键title
    > db.c.update({"name" : "toyota"},{$push:{"title":"t1"}})
    > db.c.find()
    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
     "width" : 7, "length" : 15 }, "title" : [ "t1" ], "type" : "suv" }
    
    --再向title中push一个值
    > db.c.update({"name" : "toyota"},{$push:{"title":"t2"}})
    > db.c.find()
    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
     "width" : 7, "length" : 15 }, "title" : [ "t1", "t2" ], "type" : "suv" }
    

    结合$each子修改器一次性添加多个元素。

    > db.c.update({"name" : "toyota"},{$push:{"title":{$each:["t1","t2","t3"]}}})
    

    数组修改器-- $ne/$addToSet

    $ne:表示值不存在时添加,而$addToSet表示已存在时不添加(如果本身已存在重复值,它不会去重)。

    > db.c.update({"title" : {$ne:"t2"}},{$push:{"title":"t2"}})
    > db.c.find()
    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
     "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t2" ], "type" : "suv" }
    
    > db.c.update({"name" : "toyota"},{$addToSet:{"title":"t2"}})
    > db.c.find()
    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
     "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t2" ], "type" : "suv" }
    

    推荐使用$addToSet.

    数组修改器-- $pop$pull

    $pop表示从数组的头或者尾删除数组中的元素,1表示从尾部删除,-1表示从头部删除。

    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
     "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t3", "t4" ],"type" : "suv" }
    

    --从数组的尾部删除 1

    > db.c.update({"name" : "toyota"},{$pop:{"title":1}})
    > db.c.find()
    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
     "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t3" ], "type" : "suv" }
    

    --从数组的头部 -1

    	> db.c.update({"name" : "toyota"},{$pop:{"title":-1}})
    	> db.c.find()
    	{ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
    	 "width" : 7, "length" : 15 }, "title" : [ "t2", "t3" ], "type" : "suv" }
    

    --从数组的尾部删除 0

    > db.c.update({"name" : "toyota"},{$pop:{"title":0}})
    > db.c.find()
    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
     "width" : 7, "length" : 15 }, "title" : [ "t2" ], "type" : "suv" }
    

    $pull从数组中删除满足条件的元素,示例如下:

    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
     "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t2", "t3" ],"type" : "suv" }
    
    > db.c.update({"name" : "toyota"},{$pull:{"title":"t2"}})
    > db.c.find()
    { "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8,
     "width" : 7, "length" : 15 }, "title" : [ "t1", "t3" ], "type" : "suv" }
    

    数组的定位修改器

    在需要对数组中的值进行操作的时候,可通过array.index来指定修改的具体位置。也可以通过array.$来指定。
    之所以出现后一种情况的原因是,在不可见文档的情况下,我们并不清楚值所在数组的具体下标,另外需要注意的是,通过后一种方式,只能修改匹配到的第一个元素。

    示例如下:

    {"uid":"001",comments:[{"name":"t1","size":10},{"name":"t2","size":12}]}
    

    通过指定具体下标来修改:

    > db.c.update({"uid":"001"},{$inc:{"comments.0.size":1}})
    > db.c.find({"uid":"001"})
    { "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {
    "name" : "t1", "size" : 11 }, { "name" : "t2", "size" : 12 } ] }
    

    通过使用定位修改器$来修改:

    > db.c.update({"comments.name":"t1"},{$set:{"comments.$.size":1}})
    > db.c.find({"uid":"001"})
    { "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {
    "name" : "t1", "size" : 1 }, { "name" : "t2", "size" : 12 } ] }
    

    再次强调:若为多个文档满足条件,则只更新第一个文档。

    $upsert

    顾名思义,表示更新插入的意思,它是update函数的第三个参数

    当值为true时,如果没有找到符合更新条件,则执行插入操作。

  • 相关阅读:
    Mootools中的Class应用
    预初始化对象(OnPreInit)
    新博客开张
    ASP.NET获取客户端相关信息
    UpdatePannel中JS不执行问题
    KU990 JVAVA修改全屏
    textbox 增加click事件
    JS引用顺序的问题
    传统三层架构
    ORCALE 相关操作
  • 原文地址:https://www.cnblogs.com/yw0219/p/7368543.html
Copyright © 2020-2023  润新知