文章詳情頁
mysql for update 如果事務一直沒有提交會不會這表數據一直鎖在那里
瀏覽:222日期:2022-06-15 08:55:29
問題描述
mysql for update 鎖住了一條或多條數據,或者是整個表 如果事務一直沒有提交(比如服務器掛掉了)會不會這表數據一直鎖在那里
問題解答
回答1:不會??蛻舳诉B接斷開后,會自動釋放鎖。
客戶端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 commit 或 rollback 。但是,如果客戶端1直接關閉窗口斷開連接,客戶端2也能直接拿到鎖。說明客戶端斷開時,會自動釋放鎖。
那么問題來了,客戶端1斷開連接后,是自動 rollback 了嗎?
相關文章:
1. debian - docker依賴的aufs-tools源碼哪里可以找到???2. dockerfile - 我用docker build的時候出現下邊問題 麻煩幫我看一下3. angular.js使用$resource服務把數據存入mongodb的問題。4. docker gitlab 如何git clone?5. docker 下面創建的IMAGE 他們的 ID 一樣?這個是怎么回事????6. macos - mac下docker如何設置代理7. javascript - 連續點擊觸發mouseleave事件8. docker網絡端口映射,沒有方便點的操作方法么?9. docker start -a dockername 老是卡住,什么情況?10. docker api 開發的端口怎么獲?。?/a>
排行榜

網公網安備