mongo update 基础修改

mongo 修改 update

参数:

query  查询条件

update 修改条件

upsert (true, flase) 默认为false 如果为true 就是如果数据不存在则新建数据

multi (true,false) 默认为false 如果为true  符合query 条件全部修改 默认只修改第一条

 

 

$inc 按指定的字段增加字段的值  

注:如果$inc指定的字段为空值时会报错, 如果字段不存在 则设置该字段为新值

({name: cjl},{$inc: {age: -3}})

 

$mul 将字段的值乘指定的值

({name: cjl},{$mul:{gid: 2}}

 

$rename  修改指定字段名称

({"name": "周岩"}, {"$rename": {"states": "state", "phones": "phone"}})

 

 

$set 字段更新操作符号

https://blog.csdn.net/yaomingyang/article/details/78790149

 

$unset 删除指定字段

如果该字段不存在,则不$unset执行任何操作(即无操作)。

({"name": "曹俊良"}, {"$unset": {"lang": true}})

 

$min 字段值大于指定的值的时候更新字段的值为指定的值

注:如果指定的字段不存在的话会设置该字段的值为指定的值

操作符可以比较不同类型的数据根据BSON比较数据的规则

 

$max 字段值小于指定的值得时候更新字段的值为指定的值

注:如果指定的字段不存在的话会设置该字段的值为指定的值

操作符可以比较不同类型的数据根据BSON比较数据的规则

 

$currmentDate  更新文档字段时间 值得类型可以为(timestamp,date)默认date 

注: 类型为小写

{"name": "王五"}, {"$currentDate": {"times": {"$type": "date"}}}, {"multi": true}

结果:

{

    "_id" : ObjectId("5d4d183da5f379bf10668197"),

    "name" : "王五",

    "age" : 21.0,

    "lang" : [ 

        "python", 

        "go"

    ],

    "times" : ISODate("2019-08-09T07:32:23.242Z")

}

 

$setOnInsert  与upsert

注: 如果update的更新参数upsert:true,也就是如果要更新的文档不存在的话会插入一条新的记录,$setOnInsert操作符会将指定的值赋值给指定的字段,如果要更新的文档存在那么[$setOnInsert操作符不做任何处理]

 

({_id: 1}, {$set:{name:cjl},$setOnInsert:{default: 100}}, {upsert:true})

如果upsert:true, 且id 为 1 文档不存在 则创建一条新数据 

 

{_id:1,name:cjl,default:100}

如果数据存在的话将会更新$set操作符指定的值,忽略掉$setOnInsert指定的值

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值