文章詳情頁
mysql for update 如果事務(wù)一直沒有提交會不會這表數(shù)據(jù)一直鎖在那里
瀏覽:92日期: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. docker-compose中volumes的問題2. vim - docker中新的ubuntu12.04鏡像,運(yùn)行vi提示,找不到命名.3. python 多進(jìn)程 或者 多線程下如何高效的同步數(shù)據(jù)?4. docker 下面創(chuàng)建的IMAGE 他們的 ID 一樣?這個是怎么回事????5. docker-compose 為何找不到配置文件?6. php - 想要遠(yuǎn)程推送emjio ios端怎么搞 需要怎么配合7. java - Hibernate查詢的數(shù)據(jù)是存放在session中嗎?8. 一個走錯路的23歲傻小子的提問9. angular.js - node.js中下載的angulae無法引入10. android - 添加multidex后在部分機(jī)型上產(chǎn)生anr的問題,該如何解決
排行榜

熱門標(biāo)簽