文章詳情頁
mysql for update 如果事務一直沒有提交會不會這表數據一直鎖在那里
瀏覽:133日期: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. Docker for Mac 創建的dnsmasq容器連不上/不工作的問題2. html5 - 這個代碼顯示功能如何實現?3. java - 一段遞歸代碼的問題4. java - instance method中 static后的<K>是什么意思?5. node.js - npm 非管理員權限 全局安裝問題6. java - 關于File的問題?7. python3.x - python連oanda的模擬交易api獲取json問題第五問8. javascript - QWebEngineView 如何爬 angular 的動態數據?9. node.js - 終端 遠程連接服務器,終端關閉后,服務器無法運行10. docker - 如何修改運行中容器的配置
排行榜
