V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
? MySQL 5.5 Community Server
? MySQL 5.6 Community Server
? Percona Configuration Wizard
? XtraBackup 搭建主从复制
Great Sites on MySQL
? Percona
? MySQL Performance Blog
? Severalnines
推荐管理工具
? Sequel Pro
? phpMyAdmin
推荐书目
? MySQL Cookbook
MySQL 相关项目
? MariaDB
? Drizzle
参考文档
? http://mysql-python.sourceforge.net/MySQLdb.html
Ainokiseki
V2EX  ?  MySQL

求问关于并发更新数据库的潜在数据冲突

  •  
  •   Ainokiseki · 17 天前 · 836 次点击
    ```UPDATE mytable set max_offset = ? where id='xxx' and max_offset < ?``` (传入?的两个值相同)

    上面这条 sql 语句,如果 n 个线程并发执行,对应的值分别为 1 ,2 ,……,n ,是否有可能最终得到的 max\_offset 不是最大值 n?是否需要加锁来保证并发安全?数据库隔离级别为 read\_commited
    5 条回复  ?  2024-04-18 17:19:43 +08:00
    sagaxu
        1
    sagaxu  
       17 天前
    update 或者 select for update 自己会锁,不用额外加锁
    kanepan19
        2
    kanepan19  
       17 天前
    你的语句本身就是线程安全的, 执行的有的会成功,有的会失败, 判断好,执行结果就行
    LiaoMatt
        3
    LiaoMatt  
       17 天前
    不论隔离级别是啥都不允许脏写, update 是当前读, 你的条件会加间隙锁,其他的事务会阻塞,直到事务提交,或者超时
    siweipancc
        4
    siweipancc  
       17 天前 via iPhone
    最终一致性只要执行 n++就行,只要接受每次更新返回的结果跟预期不一致,或者改成乐观更新,这样子就是可预期的
    andykuen959595
        5
    andykuen959595  
       17 天前
    试试先查询 插入临时表 最后根据主键进行修改
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2513 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 11:56 · PVG 19:56 · LAX 04:56 · JFK 07:56
    Developed with CodeLauncher
    ? Do have faith in what you're doing.


    http://www.vxiaotou.com