mongodb dml

覆盖整个文档
> 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" },
...    { $pull All: { 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/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/26239116/viewspace-1485422/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值