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指定的值