文章詳情頁
mysql for update 如果事務(wù)一直沒有提交會不會這表數(shù)據(jù)一直鎖在那里
瀏覽:127日期:2022-06-15 08:55:29
問題描述
mysql for update 鎖住了一條或多條數(shù)據(jù),或者是整個表 如果事務(wù)一直沒有提交(比如服務(wù)器掛掉了)會不會這表數(shù)據(jù)一直鎖在那里
問題解答
回答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 commit 或 rollback 。但是,如果客戶端1直接關(guān)閉窗口斷開連接,客戶端2也能直接拿到鎖。說明客戶端斷開時,會自動釋放鎖。
那么問題來了,客戶端1斷開連接后,是自動 rollback 了嗎?
相關(guān)文章:
1. mysql - msyql 判斷字段不為空 簡單方法2. docker gitlab 如何git clone?3. 關(guān)docker hub上有些鏡像的tag被標記““This image has vulnerabilities””4. dockerfile - [docker build image失敗- npm install]5. java - yuicompressor-maven-plugin 合并可用卻不壓縮, 哪配置不對?6. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?7. html5 - vue 里的Elemen UI的時間怎么轉(zhuǎn)化為時間戳嗎8. linux - mysql源碼安裝遇到的問題9. javascript - Vue 自定義控件v-model雙向綁定10. angular.js使用$resource服務(wù)把數(shù)據(jù)存入mongodb的問題。
排行榜

熱門標簽