mongodb 批量 动态更新列值

mongodb中需要修改某列值可以使用$set 设置。但如果是动态修改,如在原有值上append其他字符,或则对列值进行更为复杂的更新,则需要在shell中脚本更新。

如 将userid值,前加固定字符“test”。在IntelliShell中执行一下代码

db.getCollection("Log")
  .find({"_id":"5bc05a6c4e96b32bfc8d03cc"})
  .forEach(
  	  function(e,i){
  	    e.UserId="test"+e.UserId;
  	    db.getCollection("Log").save(e);  	    
  	  }
  );
db.getCollection("Log").find({"_id":"5bc05a6c4e96b32bfc8d03cc"},{UserId:1});

执行结果:

对符合查询条件的数据,批量更新字段,没有该字段,则自动添加;

db.SimilarVectors.find({
    "Category" : "2051",
    "MainNewsPublishTime":{
        $gte:ISODate("2017-10-18T02:51:00"),
        $lte:ISODate("2017-10-19T02:51:00")
    }
}).forEach(
   function(item){                 
       db.SimilarVectors.update({"_id":item._id},{"$set":                 
       {"LastUpdateTime":item.MainNewsPublishTime,"aaa":item.AAAA}},false,false)}
);
print("end")

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值