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

[经验分享] MongoDB修改数据update和save方法

[复制链接]

尚未签到

发表于 2018-10-28 06:03:50 | 显示全部楼层 |阅读模式
前面我简单介绍了下MongoDB怎样插入数据.那么数据插入到数据库中,就可能会修改数据.在MongoDB中,它提供了修改数据的方法:update.下面,我来简单说下update的使用方法.  首先,我们操作的数据都存放在test数据库中的name集合,集合中有4条记录如下:
  > db
  test
  > show collections
  name
  system.indexes
  > db.name.find()
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "xiaoqiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "dengdeng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
  下面我们来试着修改一下这些数据.在前面的插入中,我说过,插入时可以以文档的的方式插入,也可以先把文档赋值给变量,再以变量的方式插入.update方法也可以用这两种方式.我先用文档的方式来修改集合中的第二条记录,命令如下:
  > db.name.update({"_id" : ObjectId("5059223a955cfb1fd75066cc")},{"fname" : "qiang", "lname" : "he"})
  > db.name.find()    #检查发现,数据修改过来了,和预期的结果一样
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "dengdeng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
  我们再用变量的方式来修改该集合中的第三条记录.首先将它找出来赋值给变量someone:
  > someone=db.name.findOne({"_id" : ObjectId("50592245955cfb1fd75066cd")})
  {
  "_id" : ObjectId("50592245955cfb1fd75066cd"),
  "fname" : "dengdeng",
  "lname" : "pan"
  }
  重新赋值你要修改的内容来修改变量someone的值:
  > someone.fname="deng"
  deng
  用修改过的变量替换之前文档的位置来达到修改数据的目的:
  > db.name.update({"_id" : ObjectId("50592245955cfb1fd75066cd")},someone)
  > db.name.find()    #检查发现,数据修改过来了,和预期的结果一样
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
  之前我说过,save函数实际就是根据参数条件,调用了insert或update函数.那么save方法是否也能实现数据的修改操作呢?下面我们来实验一下.首先还是以文档的方式来进行修改操作:
  > db.name.save({"_id" : ObjectId("50592253955cfb1fd75066ce")}, {"fname" : "dongren", "lname" : "zeng"})
  > db.name.find()    #检查发现,数据修改过来了,但和预期的结果不一样,跟之前插入数据一样,save方法也同样将第二个参数"忽略"了.
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce") }
  正确的操作方式如下:
  > db.name.save({"_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "dongren", "lname" : "zeng"})
  > db.name.find()    #检查发现,数据修改过来了,和预期的结果一样
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "dongren", "lname" : "zeng" }
  下面使用变量的方式来修改:
  > someone=db.name.findOne({"_id" : ObjectId("50592253955cfb1fd75066ce")})
  {
  "_id" : ObjectId("50592253955cfb1fd75066ce"),
  "fname" : "dongren",
  "lname" : "zeng"
  }
  > someone.fname="guage"
  guage
  > db.name.save(someone)
  > db.name.find()    #检查发现,数据修改过来了,和预期的结果一样
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
  下面,我们也同样来看看save和update这两方法的具体实现.首先是save方法:
  > db.name.save
  function (obj) {
  if (obj == null || typeof obj == "undefined") {
  throw "can't save a null";
  }
  if (typeof obj == "number" || typeof obj == "string") {
  throw "can't save a number or string";
  }
  if (typeof obj._id == "undefined") {
  obj._id = new ObjectId;
  return this.insert(obj);
  } else {
  return this.update({_id:obj._id}, obj, true);
  }
  }
  参数说明:
  obj:要更新的记录,只能是单条记录,如果collection没有存在与obj一样的id,则添加一条记录,否则更新.
  再来看看update方法:
  > db.name.update
  function (query, obj, upsert, multi) {
  assert(query, "need a query");
  assert(obj, "need an object");
  var firstKey = null;
  for (var k in obj) {
  firstKey = k;
  break;
  }
  if (firstKey != null && firstKey[0] == "$") {
  this._validateObject(obj);
  } else {
  this._validateForStorage(obj);
  }
  if (typeof upsert === "object") {
  assert(multi === undefined, "Fourth argument must be empty when specifying upsert and multi with an object.");
  opts = upsert;
  multi = opts.multi;
  upsert = opts.upsert;
  }
  this._db._initExtraInfo();
  this._mongo.update(this._fullName, query, obj, upsert ? true : false, multi ? true : false);
  this._db._getExtraInfo("Updated");
  }
  参数说明:
  1)query:查询条件,类似于update语句内where后面的内容
  2)obj:update的对象和一些更新的操作符(如$、$inc等),也可以理解为关系型数据库update语句内set后面的内容
  3)upsert:如果不存在update的纪录,是否插入obj这个新的document。true为插入,默认是false,不插入
  4)multi:默认是false,只更新找到的第一条纪录,如果为true,按条件查出来的多条纪录全部更新。
  update方法至少得接收两个参数:要修改的对象(query)和修改后的对象(obj),而后两个参数它的默认值均为false.下面我再来简单实验下,后两个参数的基本用法.
  首先说说第四个参数multi的作用:默认是false,只更新找到的第一条纪录,如果为true,按条件查出来的多条纪录全部更新.
  > db.name.update({fname:"jeff"},{$set:{lname:"li"}},false,false)    #为了让大家看得清楚点,我把后两个值都写了出来,这里可以不用写的,因为默认均为false.这里用到了修改器$set,关于修改器我将在以后介绍
  > db.name.find()    #参数multi的值是false,只更新找到的第一条纪录
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "li" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
  { "_id" : ObjectId("50592ead955cfb1fd75066cf"), "fname" : "jeff", "lname" : "chen" }
  { "_id" : ObjectId("50592ecb955cfb1fd75066d0"), "fname" : "jeff", "lname" : "zhao" }
  { "_id" : ObjectId("50592edb955cfb1fd75066d1"), "fname" : "jeff", "lname" : "qian" }
  > db.name.update({fname:"jeff"},{$set:{lname:"jiang"}},false,true)
  > db.name.find()    #参数multi的值是true,更新找到的所有纪录
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
  { "_id" : ObjectId("50592ead955cfb1fd75066cf"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("50592ecb955cfb1fd75066d0"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("50592edb955cfb1fd75066d1"), "fname" : "jeff", "lname" : "jiang" }
  再来看看第三个参数upsert的作用:如果不存在update的纪录,是否插入obj这个新的document。true为插入,默认是false,不插入.
  > db.name.update({fname:"jeffery"},{$set:{lname:"jiang"}},false,true)
  > db.name.find()  #参数upsert的值是false,不插入
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
  { "_id" : ObjectId("50592ead955cfb1fd75066cf"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("50592ecb955cfb1fd75066d0"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("50592edb955cfb1fd75066d1"), "fname" : "jeff", "lname" : "jiang" }
  > db.name.update({fname:"jeffery"},{$set:{lname:"jiang"}},true,true)
  > db.name.find()  #参数upsert的值是true,插入.又学到一种插入数据的方法!
  { "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
  { "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
  { "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
  { "_id" : ObjectId("50592ead955cfb1fd75066cf"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("50592ecb955cfb1fd75066d0"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("50592edb955cfb1fd75066d1"), "fname" : "jeff", "lname" : "jiang" }
  { "_id" : ObjectId("5059357ad3ba22406ad408e6"), "fname" : "jeffery", "lname" : "jiang" }
  update方法操作其实还是有点复杂的,这里我只简单地介绍了下它的基体操作,复杂的操作是合理利用各种修改器,以达到更高效更方便的管理.关于修改器的使用,我将在以后实验.


运维网声明 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-627236-1-1.html 上篇帖子: MongoDB vs Cassandra 下篇帖子: MongoDB使用$set和$inc修改器更新数据
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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