关闭

Mongodb 中常用的更新操作

标签: mongodb
161人阅读 评论(0) 收藏 举报
分类:

上期我们介绍了mongodb 中常用的查询操作,这期说说Mongodb 中常用的更新操作。在Mongodb中更新的命令只有两条。1.update() 2.save()
1. update() 语法规则 :db.collection.update( A, B, C, D ) 。A ,B,C,D四个参数的解释
A 表示update的查询条件,类似sql update查询内where后面的。
B 表示 update的对象和一些更新的操作符(如inc…)等,也可以理解为sql update查询内set后面的
C 这个参数的意思是,如果不存在update的记录,是否插入B,true为插入,默认是false,不插入。
D mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
例子:
db.test0.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } ); 只更新了第一条记录
db.test0.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true ); 全更新了
db.test0.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false ); 只加进去了第一条
db.test0.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true ); 全加进去了
db.test0.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );全更新了
db.test0.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );只更新了第一条

2.save()
db.collection.save( x ) x就是要更新的对象,只能是单条记录。如果在collection内已经存在一个和x对象相同的”_id”的记录。mongodb就会把x对象替换collection内已经存在的记录,否则将会插入x对象,如果x内没有_id,系统会自动生成一个再插入。相当于上面update语句的C=true,D=false的情况。例子:db.test0.save({count:40,test1:”OK”}); #_id系统会生成
db.test0.save({_id:40,count:40,test1:”OK”}); #如果test0内有_id等于40的,会替换,否则插入。
3. Mongodb 更新中常用的操作符
1.$inc 用法{ $inc : { field : value } }意思对一个数字字段field增加value。

> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 16, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

> db.test0.update( { "_id" : 15 } , { $inc : { "count" : 1 } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 17, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

2.$set 用法:{ $set : { field : value } }意思就是相当于sql的set field = value,全部数据类型都支持$set。

> db.test0.update( { "_id" : 15 } , { $set : { "test1" : "testv1","test2" : "testv2","test3" : "testv3","test4" : "testv4" } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : "testv1", "test2" : "testv2", "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }

3.$unset 用法:{ $unset : { field : 1} } 意思就是删除字段

意思就是删除test0 这个表中的test1:1 这个字段
> db.test0.update( { "_id" : 15 } , { $unset : { "test1":1 } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test2" : "testv2", "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }

4.$push 用法{ $push : { field : value } }意思就是把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去。一次只能追加一个值

就是往test0 这个表的test1 字段数组中添加ccc 这个值
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb" ], "test4" : "testv4", "test5" : "OK" }

> db.test0.update( { "_id" : 15 } , { $push : { "test1": "ccc" } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc" ], "test4" : "testv4", "test5" : "OK" }

5.$pushAll 用法 { $pushAll : { field : value_array } } 和$push 的用法一样,区别在于$push一次只能追加一个值,$pushAll可以追加多个值

就是往test1 这个字段中同时追加 fff .ggg 这个两个值
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

> db.test0.update( { "_id" : 15 } , { $pushAll : { "test1": ["fff","ggg"] } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ], "fff", "ggg" ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

6.$addToSet 用法{ $addToSet : { field : value } } 意思就是增加一个值到数组内,而且只有当这个值不在数组内才增加

> db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": {$each : ["444","555"] } } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, 


  "test1" : ["aaa","bbb","ccc",["ddd","eee"],"fff","ggg",["111","222"],"444","555"], 


  "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK"


 }

7.$pop删除数组 用法删除最后一个值:{ $pop : { field : 1 } }删除第一个值:{ $pop : { field : -1 } } 意思就是删除数组内某一个值,只能删除一个值,也就是说只能用1或-1

   > db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, 


  "test1" : ["bbb","ccc",["ddd","eee"],"fff","ggg",["111","222"],"444"], 


  "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" 


}
> db.test0.update( { "_id" : 15 } , { $pop : { "test1": -1 } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, 


  "test1" : ["ccc",["ddd","eee"],"fff","ggg",["111","222"],"444"], 


  "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK"

 } 

8.$pull 用法:$pull : { field : value } } 意思就是 从数组field内删除一个等于value值

意思就是删除test0 这个表中test1 数组中的等于ggg 这个值
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", "ggg", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4",
"test5" : "OK" }

> db.test0.update( { "_id" : 15 } , { $pull : { "test1": "ggg" } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5"
: "OK" }

9.$pullAll 用法{ $pullAll : { field : value_array } } 和$pull差不多,就是可以一次删除多个值
更多关于mongodb 操作数据的方法和参数可以参考mongodb 的官方文档

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:12368次
    • 积分:477
    • 等级:
    • 排名:千里之外
    • 原创:36篇
    • 转载:0篇
    • 译文:0篇
    • 评论:14条
    最新评论