设为首页 收藏本站
查看: 1434|回复: 0

[经验分享] mongoDB数据更新与操作符

[复制链接]

尚未签到

发表于 2017-12-15 21:05:15 | 显示全部楼层 |阅读模式
  //转载
  1).update()命令
  db.collection.update( criteria, objNew, upsert, multi )
  criteria  : update的查询条件,类似sql update查询内where后面的
  objNew : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
  upsert  : 这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
  multi     : 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语句的upsert=true,multi=false的情况。
  例:
  db.test0.save({count:40,test1:"OK"}); #_id系统会生成
  db.test0.save({_id:40,count:40,test1:"OK"}); #如果test0内有_id等于40的,会替换,否则插入。
  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" }
  > db.test0.update( { "_id" : 15 } , { $inc : { "count" :2 } } );
  > db.test0.find( { "_id" : 15 } );
  { "_id" : { "floatApprox" : 15 }, "count" : 19,"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" : 18,"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} }
  顾名思义,就是删除字段了。例:
  > 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" }
  > db.test0.update( { "_id" : 15 } , { $unset : {"test2": 0 } } );
  > db.test0.find( { "_id" : 15 } );
  { "_id" : { "floatApprox" : 15 }, "count" : 18,"test3" : "testv3", "test4" : "testv4","test5" : "OK" }
  > db.test0.update( { "_id" : 15 } , { $unset : {"test3":asdfasf } } );
  Fri May 14 16:17:38 JS Error: ReferenceError: asdfasf is not defined (shell):0
  > db.test0.update( { "_id" : 15 } , { $unset : { "test3":"test"} } );
  > db.test0.find( { "_id" : 15 } );
  { "_id" : { "floatApprox" : 15 }, "count" : 18,"test4" : "testv4", "test5" : "OK" }
  没看出field : 1里面的1是干什么用的,反正只要有东西就行。
  4) $push
  用法:{ $push : { field :value } }
  把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去。例:
  > db.test0.update( { "_id" : 15 } , { $set : { "test1" :["aaa","bbb"] } } );
  > 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" }
  > db.test0.update( { "_id" : 15 } , { $push : { "test2":"ccc" } } );
  > db.test0.find( { "_id" : 15 } );
  { "_id" : { "floatApprox" : 15 }, "count" : 18,"test1" : [ "aaa", "bbb", "ccc" ],"test2" : [ "ccc" ], "test4" :"testv4", "test5" : "OK" }
  > db.test0.update( { "_id" : 15 } , { $push : { "test1":["ddd","eee"] } } );
  > db.test0.find( { "_id" : 15 } );
  { "_id" : { "floatApprox" : 15 }, "count" : 18,"test1" : [ "aaa", "bbb", "ccc", ["ddd", "eee" ] ], "test2" : [ "ccc" ],"test4" : "testv4", "test5" : "OK" }
  5) $pushAll
  用法:{ $pushAll : { field : value_array } }
  同$push,只是一次可以追加多个值到一个数组字段内。例:
  > 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" }
  > 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" }
  > db.test0.update( { "_id" : 15 } , { $addToSet : {"test1": ["444","555"]  } } );
  > db.test0.find( { "_id" : 15 } );
  { "_id" : { "floatApprox" : 15 }, "count" : 18,"test1" : [ "aaa","bbb", "ccc", ["ddd", "eee" ], "fff", "ggg", [ "111", "222" ], "444", "555", [ "444", "555"]], "test2" : [ "ccc" ], "test4" : testv4", "test5" : "OK" }
  > db.test0.update( { "_id" : 15 } , { $addToSet : {"test1": ["444","555"]  } } );
  > db.test0.find( { "_id" : 15 } );
  { "_id" : { "floatApprox" : 15 }, "count" : 18,"test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ], "fff", "ggg", [ "111", "222" ], "444", "555", [ "444", "555" ]], "test2" : [ "ccc" ], "test4" :"testv4", "test5" : "OK" }
  7) $pop
  删除数组内的一个值
  用法:
  删除最后一个值:{ $pop : { field : 1  } }
  删除第一个值:{ $pop : {field : -1  } }
  注意,只能删除一个值,也就是说只能用1或-1,而不能用2或-2来删除两条。mongodb1.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" }
  > 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" ] ],"test2" : [ "ccc" ], "test4" :"testv4",
  "test5" : "OK" }
  8) $pull
  用法:$pull : { field : value } }
  从数组field内删除一个等于value值。例:
  > 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,可以一次删除数组内的多个值。例:
  > db.test0.find( { "_id" : 15 } );
  { "_id" : { "floatApprox" : 15 }, "count" : 18,"test1" : [ "ccc", [ "ddd", "eee" ],"fff", [ "111", "222" ] ], "test2" : ["ccc" ], "test4" : "testv4", "test5"
  : "OK" }
  > db.test0.update( { "_id" : 15 } , { $pullAll : {"test1": [ "ccc" , "fff" ] } } );
  > db.test0.find( { "_id" : 15 } );
  { "_id" : { "floatApprox" : 15 }, "count" : 18,"test1" : [ [ "ddd", "eee" ], [ "111","222" ] ], "test2" : [ "ccc" ], "test4": "testv4", "test5" : "OK" }
  10) $ 操作符
  $是他自己的意思,代表按条件找出的数组里面某项他自己。呵呵,比较坳口。看一下官方的例子:
  > t.find()
  { "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"),"title" : "ABC", "comments" : [ { "by" : "joe","votes" : 3 }, { "by" : "jane", "votes": 7 } ] }
  > t.update( {'comments.by':'joe'}, {$inc:{'comments.$.votes':1}}, false,true )
  > t.find()
  { "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"),"title" : "ABC", "comments" : [ { "by" : "joe","votes" : 4 }, { "by" : "jane", "votes": 7 } ] }
  需要注意的是,$只会应用找到的第一条数组项,后面的就不管了。还是看例子:
  > t.find();
  { "_id" : ObjectId("4b9e4a1fc583fa1c76198319"),"x" : [ 1, 2, 3, 2 ] }
  > t.update({x: 2}, {$inc: {"x.$": 1}}, false, true);
  > t.find();
  还有注意的是$配合$unset使用的时候,会留下一个null的数组项,不过可以用{$pull:{x:null}}删除全部是null的数组项。例:
  > t.insert({x: [1,2,3,4,3,2,3,4]})
  > t.find()
  { "_id" : ObjectId("4bde2ad3755d00000000710e"),"x" : [ 1, 2, 3, 4, 3, 2, 3, 4 ] }
  > t.update({x:3}, {$unset:{"x.$":1}})
  > t.find()
  { "_id" : ObjectId("4bde2ad3755d00000000710e"),"x" : [ 1, 2, null, 4, 3, 2, 3, 4 ] }
  { "_id" : ObjectId("4b9e4a1fc583fa1c76198319"),"x" : [ 1, 3, 3, 2 ] }

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-424504-1-1.html 上篇帖子: nodejs mongodb 数据库封装DB类 下篇帖子: MongoDB C++ gridfs worked example
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表