mongo数据库之“upsert”(一种特殊的更新)

本文介绍了MongoDB中upsert方法,它是一种特殊更新,若未找到符合条件文档,会以条件和更新文档创建新文档;若找到则正常更新。该方法语法在更新基础上加第三个参数true,能避免竞态问题,减少代码量,更高效且具原子性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

upsert:

   是一种特殊的更新,如果没有找到符合条件的更新条件的文档,就会以这个条件和更新文档为基础创建一个新的文档;如果找到了匹配的文档,就正常更新,upsert非常方便,不必预置集合,同一套代码既能用于创建文档又可以更新文档

其语法和更新的语法一样,只是在更新的基础上多加第三个参数-->true:如下

# 语法:

db.stu.update({"_id": 3}, {用于更新的文档内容}, “这里就是要添加的第三个参数,是固定的!”)

例:

db.stu.update({"_id": 3}, {"$set": {"name": "wang"}}, true)

演示效果如下:

 所以这个方法适用于:以更新条件为基础,如果查到对应数据,则将对应数据更新,如果查不到对应数据,那么则以更新条件新增一条数据!

优点:

设想,如果我们对某种数据操作都是先查数据库,确定是否有对应文档,再决定更新还是插入,那么在多个进程同时操作同一段代码,或者多个进程/线程操作同一个条件时,就会遇到同时对给定条件插入多个文档这样的竞态条件,    但是,使用upsert,既可以避免这种竞态问题,又可以减少代码量,并且这样会更高效,是原子性的

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值