V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐工具
RoboMongo
推荐书目
50 Tips and Tricks for MongoDB Developers
Related Blogs
Snail in a Turtleneck
Grand
V2EX  ›  MongoDB

MongoDB 的 findOneAndUpdate 并发问题

  •  
  •   Grand · 236 天前 · 1478 次点击
    这是一个创建于 236 天前的主题,其中的信息可能已经有所发展或是发生改变。
    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 条回复    2024-03-13 13:02:54 +08:00
    zhangqian99
        1
    zhangqian99  
       236 天前
    虽然两个线程同时尝试执行 findOneAndUpdate 操作,因为操作的原子性,只有一个线程能成功更新文档。虽然条件相同,另一个线程会找不到匹配的文档来更新
    cyhulk
        2
    cyhulk  
       236 天前
    @zhangqian99 他的问题是 find 并发的时候能不能读到,感觉可以读到但是更新不了,没有 mysql 的那些事务隔离吧
    shakeyo
        3
    shakeyo  
       236 天前
    可以读到但更新不了,读取跟更新是一个原子操作,没有更新的线程不会读取到数据,因为 status 已经改变
    bug123
        4
    bug123  
       235 天前
    @shakeyo 这种情况不应该是第二个线程阻塞等第一个线程 update 完吗?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   890 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 18ms · UTC 22:13 · PVG 06:13 · LAX 14:13 · JFK 17:13
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.