mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里
迷茫
迷茫 2017-04-17 16:27:28
0
1
1199

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

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回覆(1)
巴扎黑

不會。用戶端連線斷開後,會自動釋放鎖。

客戶端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也能直接拿到鎖。 說明客戶端斷開時,會自動釋放鎖定commitrollback 。但是,如果客户端1直接关闭窗口断开连接,客户端2也能直接拿到锁。说明客户端断开时,会自动释放锁

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

那麼問題來了,客戶端1斷開連線後,是自動 rollback 了嗎? 🎜
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!