V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
推荐工具
RoboMongo
推荐书目
50 Tips and Tricks for MongoDB Developers
Related Blogs
Snail in a Turtleneck
dapen
V2EX  ›  MongoDB

MongoDB 的 findOneAndUpdate 并发问题

  •  
  •   dapen · Mar 12, 2024 · 4104 views
    This topic created in 784 days ago, the information mentioned may be changed or developed.
    MongoDB 有一个 Document ,它的 Schema 如下
    {
    "_id": ObjectId // 主键
    "status": String
    }
    数据库里面有一条数据
    {
    "_id": 1,
    "status": "waiting"
    }
    现在两个线程 A,B ,线程 A 和 B 并发执行 findOneAndUpdate({"_id": "1", "status": "waiting"}, {$set: { "status": "running"}})
    虽然 findOneAndUpdate 是原子操作,但是有没有可能同时查找出该文档。
    4 replies    2024-03-13 13:02:54 +08:00
    zhangqian99
        1
    zhangqian99  
       Mar 12, 2024
    虽然两个线程同时尝试执行 findOneAndUpdate 操作,因为操作的原子性,只有一个线程能成功更新文档。虽然条件相同,另一个线程会找不到匹配的文档来更新
    cyhulk
        2
    cyhulk  
       Mar 12, 2024
    @zhangqian99 他的问题是 find 并发的时候能不能读到,感觉可以读到但是更新不了,没有 mysql 的那些事务隔离吧
    shakeyo
        3
    shakeyo  
       Mar 12, 2024
    可以读到但更新不了,读取跟更新是一个原子操作,没有更新的线程不会读取到数据,因为 status 已经改变
    bug123
        4
    bug123  
       Mar 13, 2024
    @shakeyo 这种情况不应该是第二个线程阻塞等第一个线程 update 完吗?
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   755 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 39ms · UTC 21:18 · PVG 05:18 · LAX 14:18 · JFK 17:18
    ♥ Do have faith in what you're doing.