V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
esolve
V2EX  ›  问与答

read uncommited 和共享锁的问题

  •  
  •   esolve · 2017-03-30 16:33:17 +08:00 · 1433 次点击
    这是一个创建于 2856 天前的主题,其中的信息可能已经有所发展或是发生改变。

    http://blog.csdn.net/flyingfalcon/article/details/53045672

    这篇文章里说:

    1 、一级封锁协议 (对应 read uncommited)    一级封锁协议是:事务 在对需要修改的数据上面(就是在发生修改的瞬间) 对其加共享锁(其他事务不能更改,但是可以读取-导致“脏读”),直到事务结束才释放。事务结束包括正常结束( COMMIT )和非正常结束( ROLLBACK )。 一级封锁协议不能避免 丢失更新,脏读,不可重复读,幻读!

     -------------------------------------
    

    我奇怪的是,持有共享锁的事务不是不能对数据进行修改吗? 为何他说“事务 在对需要修改的数据上面对其加共享锁”?

    4 条回复    2017-03-30 20:45:34 +08:00
    domty
        1
    domty  
       2017-03-30 18:22:39 +08:00
    应该是排他锁吧,他写错了吧。

    read uncommitted 的读是不上锁的,写好像是加 x 锁。
    esolve
        2
    esolve  
    OP
       2017-03-30 19:18:36 +08:00
    @domty 排他锁的话,别的事务度不了,怎么出现脏读?
    domty
        3
    domty  
       2017-03-30 19:23:26 +08:00
    @esolve #2
    read uncommited 在读的时候是不给被读取的行加共享锁,这些数据可能被其他事务进行修改,导致脏读。
    esolve
        4
    esolve  
    OP
       2017-03-30 20:45:34 +08:00
    @domty 没懂你意思
    你说其他事务进行修改,但是其他事务修改的时候如果加 X 锁,你这个事务读不了啊
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1539 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 16:49 · PVG 00:49 · LAX 08:49 · JFK 11:49
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.