찾다

 >  Q&A  >  본문

mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里

mysql for update 锁住了一条或多条数据,或者是整个表 如果事务一直没有提交(比如服务器挂掉了)会不会这表数据一直锁在那里

迷茫迷茫2777일 전1231

모든 응답(1)나는 대답할 것이다

  • 巴扎黑

    巴扎黑2017-04-17 16:29:28

    不会。客户端连接断开后,会自动释放锁。

    客户端1

    set AUTOCOMMIT = 0;
    BEGIN;
    SELECT * FROM articles WHERE id=1 FOR UPDATE ;
    

    客户端2

    set AUTOCOMMIT = 0;
    BEGIN;
    SELECT * FROM articles WHERE id=1 FOR UPDATE ;
    

    这时,客户端2的查询会卡住。直到客户端1 commitrollback 。但是,如果客户端1直接关闭窗口断开连接,客户端2也能直接拿到锁。说明客户端断开时,会自动释放锁

    那么问题来了,客户端1断开连接后,是自动 rollback 了吗?

    회신하다
    0
  • 취소회신하다