mongodb dml

liiinuuux發表於2015-04-03
覆蓋整個文件
> db.obj.update(
...     { name: "obj2" },
...     {
...       f1: 1,
...       f2: "a"
...     }
... )
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.obj.find({f1:1})
{ "_id" : ObjectId("5502a740773fc1f962baf14e"), "f1" : 1, "f2" : "a" }


修改指定內容
更新操作支援的選項
$set          設定欄位的值
$inc          +=
$mul          *
$rename       重新命名欄位
$setOnInsert  當設定了$upsert:true,並且的確新插入了文件時,設定新文件的屬性。
$unset        刪除欄位
$min          只有當指定的值小於原有值時才更新
$max          只有當指定的值大於原有值時才更新
$currentDate  將欄位的值設定為當前時間

修改子文件的名稱和陣列,並且新增一個欄位lastModified,內容是當前時間
> db.obj.update(
...     { name: "obj1" },
...     {
...       $set: {
...         "subObj.subName": "sub-name-1",
...         "subObj.subArr": ["a", "b"]
...       },
...       $currentDate: { lastModified: true }
...     }
... )
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.obj.findOne();
{
        "_id" : ObjectId("5502a2ef773fc1f962baf14b"),
        "name" : "obj1",
        "arr" : [
                {
                        "elemName" : "elem1",
                        "elemValue" : 1
                },
                {
                        "elemName" : "elem2",
                        "elemValue" : 2
                }
        ],
        "subObj" : {
                "subName" : "sub-name-1",
                "subArr" : [
                        "a",
                        "b"
                ]
        },
        "lastModified" : ISODate("2015-03-13T08:55:27.802Z")
}


更改多行
update預設只能更改1個文件,不管匹配到多資料,最後只會顯示
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
要修改多個文件,需要用第3個引數:
> db.obj.update(
...     { name: {$regex: /bulk/} },
...     {
...       $set: {
...         "subObj.subName": "sub-name-update",
...       },
...       $currentDate: { lastModified: true }
...     },
...     {multi: true}
... )
WriteResult({ "nMatched" : 2, "nUpserted" : 0, "nModified" : 2 })


不存在則建立
> db.obj.update(
...    { name: "xxx" },
...    {
...      name: "xxx",
...      value: 123
...    },
...    { upsert: true }
... )
WriteResult({
        "nMatched" : 0,
        "nUpserted" : 1,
        "nModified" : 0,
        "_id" : ObjectId("5502ab51fa04f5d70cc725c1")
})
> db.obj.find({name: "xxx"});
{ "_id" : ObjectId("5502ab51fa04f5d70cc725c1"), "name" : "xxx", "value" : 123 }

也可以用$set
> db.obj.update(
...    { name: "yyy" },
...    {$set: {
...      name: "yyy",
...      value: 9
...    }},
...    { upsert: true }
... )
WriteResult({
        "nMatched" : 0,
        "nUpserted" : 1,
        "nModified" : 0,
        "_id" : ObjectId("5502acf6fa04f5d70cc725c2")
})
> db.obj.find({name: "yyy"})
{ "_id" : ObjectId("5502acf6fa04f5d70cc725c2"), "name" : "yyy", "value" : 9 }


為已存在的文件和新文件設定不同的值
原文件
> db.obj.find({name: "xxx"}, {_id:0});
{ "name" : "xxx", "value" : 123 }

更新為1000
> db.obj.update(
...    { name: "xxx" },
...    {
...      $set: {value: 1000},
...      $setOnInsert: {newDoc: true}
...    },
...    { upsert: true }
... );
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.obj.find({name: "xxx"}, {_id: 0});
{ "name" : "xxx", "value" : 1000 }

如果建立了新文件,設定newDoc屬性為true
> db.obj.update(
...    { name: "zzz" },
...    {
...      $set: {value: 1000},
...      $setOnInsert: {newDoc: true}
...    },
...    { upsert: true }
... );
WriteResult({
        "nMatched" : 0,
        "nUpserted" : 1,
        "nModified" : 0,
        "_id" : ObjectId("5502edf9ec6530e2da657454")
})
> db.obj.find({name: "zzz"}, {_id:0});
{ "name" : "zzz", "value" : 1000, "newDoc" : true }

注意不能$set不能和$setOnInsert包含一樣的屬性,否則在新建立文件時會報錯
> db.obj.update(
...    { name: "zzz" },
...    {
...      $set: {value: 1000},
...      $setOnInsert: {value: 2000}
...    },
...    { upsert: true }
... );
WriteResult({
        "nMatched" : 0,
        "nUpserted" : 0,
        "nModified" : 0,
        "writeError" : {
                "code" : 16836,
                "errmsg" : "Cannot update 'value' and 'value' at the same time"
        }
})


更新陣列操作支援的操作
$          更新從陣列裡取到的第一個元素。
$addToSet  如果陣列裡不包含這個元素,就新增元素。
$pop       移除陣列的第一個或最後一個元素。-1表示移除第一個。1表示移除最後一個
$pullAll   從陣列中移除所有匹配的值(指定多個值)。
$pull      從陣列中移除所有匹配的值。
$pushAll   向陣列新增多個值。
$push      向陣列新增一個值。

原資料(陣列裡有數字,和帶重複值的字串)
> db.obj.update({name: "zzz"}, {name: "zzz", value: [1,2,3,4,5,6,7,8,9, "aaa", "aaa", "bbb", "bbb", "aa", "bb"]});
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.obj.findOne({name: "zzz"});
{
        "_id" : ObjectId("5502edf9ec6530e2da657454"),
        "name" : "zzz",
        "value" : [
                1,
                2,
                3,
                4,
                5,
                6,
                7,
                8,
                9,
                "aaa",
                "aaa",
                "bbb",
                "bbb",
                "aa",
                "bb"
        ]
}

把包含a的都移除
> db.obj.update(
...    { name: "zzz" },
...    { $pull: { value : {$regex: /a/} } }
... )
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.obj.find({name: "zzz"})
{ "_id" : ObjectId("5502edf9ec6530e2da657454"), "name" : "zzz", "value" : [ 1, 2, 3, 4, 5, 6, 7, 8, 9, "bbb", "bbb", "bb" ] }

把包含bbb的,和3移除
($pullAll後面的陣列裡只能是明確的值,不支援正規表示式)
> db.obj.update(
...    { name: "zzz" },
...    { $pullAll: { value : ["bbb", 3] } }
... )
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.obj.find({name: "zzz"}, {_id:0});
{ "name" : "zzz", "value" : [ 1, 2, 4, 5, 6, 7, 8, 9, "aaa", "aaa", "aa", "bb" ] }


修改第一個匹配aaa的元素,改成AAA
(1 查詢選項裡必須有陣列元素的過濾條件, 2 "value.$"的雙引號不能省略)
> db.obj.update(
...    { name: "zzz", value: "aaa" },
...    { $set: { "value.$" : "AAA" } }
... )
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.obj.find({name: "zzz"}, {_id:0});
{ "name" : "zzz", "value" : [ 1, 2, 3, 4, 5, 6, 7, 8, 9, "AAA", "aaa", "bbb", "bbb", "aa", "bb" ] }

用$push在指定位置上插入多個
> db.obj.update(
...    { name: "zzz", value: "aaa" },
...    {
...      $push: { value : {$each: [100, 200, 300], $position: 2} },
...    }
... )
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.obj.find({name: "zzz"}, {_id:0});
{ "name" : "zzz", "value" : [ 1, 2, 100, 200, 300, 3, 4, 5, 6, 7, 8, 9, "aaa", "aaa", "bbb", "bbb", "aa", "bb" ] }
 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26239116/viewspace-1485422/,如需轉載,請註明出處,否則將追究法律責任。

相關文章