首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  Java

mysql 是如何保证并发安全

  •  
  •   chunrong918 · 5 天前 · 1704 次点击

    比如有 a 表 表中有 id 和 count 字段,有条记录 id 为 1,count 为 10 a 线程对 id 为 1 的 count+10 b 线程也对 id 为 1 的 count+10 如何确保 id 为 1 的 count 最后为 30 呢

    15 回复  |  直到 2019-04-17 14:50:58 +08:00
        1
    yunye   5 天前
    各种锁
        2
    mmdsun   5 天前 via Android
    mvcc
        3
    leviathan0992   5 天前
    InnoDB 里 Page 的修改有锁
        4
    Ja1   5 天前
    表锁、行锁、gap 锁、next-key 锁。建议看下 mysql 的事务隔离级别和锁知识
        5
    jackietsui72   5 天前 via Android
    2 楼+4 楼的回复我觉得比较完整些
        6
    littlewing   5 天前 via iPad
    @jackietsui72 update 根本没 mvcc 啥事儿,mysql 里的 mvcc 只用于快照读,所有写操作都是当前读
        7
    jackietsui72   5 天前 via Android
    @littlewing 嗯嗯,老铁说的没毛病。大体看了一下理解为了读写。
        8
    akira   5 天前
    就这个例子
    如果是用 sql 直接更新 ,应该是行锁
    如果是先读取,再更新,结果有可能是 20
        9
    carlclone   5 天前 via Android
    写写操作没并发,肯定是串行的
        10
    carlclone   5 天前 via Android
    @carlclone 我把并发跟并行搞混了,无视我的回答
        11
    DavidNineRoc   5 天前
    很简单,正常情况下不保证呗. 用锁代价又大. 所以用别的方式代替
        12
    HarryQu   5 天前
    InnoDB 行锁是通过给索引项加锁来实现的。使用行锁还是表锁需要判断 id 是否为索引项。

    如 akira 所说,
    - sql 直接更新 。
    - 先读取,再更新 。

    这两种方式的结果取决于事务的隔离级别。

    @littlewing mysql 里的 mvcc 只用于快照读,所有写操作都是当前读 。
    关于 MVCC , 我只了解个大概, 老哥你这句话是从哪本书上看到的 , 给个搜索关键词 。我对这个结论比较好奇.
        13
    littlewing   4 天前   ♥ 1
    @HarryQu
    《 MySQL 技术内幕 InnoDB 存储引擎 (第 2 版)》 6.3
    《 MYSQL 内核:INNODB 存储引擎 (卷 1)》
    and 想要更详细的结论,请看源码
        14
    littlewing   4 天前
    @HarryQu 当然,这些结论都是基于 RR 隔离级别,RC 下 select 并不会读快照
        15
    HarryQu   4 天前
    @littlewing Thanks。
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   2125 人在线   最高记录 4385   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 16ms · UTC 07:05 · PVG 15:05 · LAX 00:05 · JFK 03:05
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1