大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 MySQL表鎖詳解

MySQL表鎖詳解

更新時間:2021-01-08 17:34:27 來源:動力節點 瀏覽1619次

鎖是計算機協調多個進程或純線程并發訪問某一資源的機制。而表鎖由MySQL Server 實現,一般在執行DDL語句時會對整個表進行加鎖,比如說ALTER TABLE等操作。在執行SQL語句時,也可以明確指定對某個表進行加鎖。本文我們就來重點講述一下MySQL表鎖

 

表鎖使用的是一次性鎖技術,也就是說,在會話開始的地方使用 lock 命令將后續需要用到的表都加上鎖,在表釋放前,只能訪問這些加鎖的表,不能訪問其他表,直到最后通過 unlock tables 釋放所有表鎖。除了使用 unlock tables 顯示釋放鎖之外,會話持有其他表鎖時執行lock table 語句會釋放會話之前持有的鎖;會話持有其他表鎖時執行 start transaction 或者 begin 開啟事務時,也會釋放之前持有的鎖。

 

由于MyISAM存儲引擎使用的鎖定機制完全是由MySQL提供的表級鎖定實現,所以下面我們將以MyISAM存儲引擎作為示例存儲引擎。

1.MySQL表級鎖的鎖模式

MySQL的表級鎖有兩種模式:表共享讀鎖(Table Read Lock)和表獨占寫鎖(Table Write Lock)。鎖模式的兼容性:

對MyISAM表的讀操作,不會阻塞其他用戶對同一表的讀請求,但會阻塞對同一表的寫請求;

對MyISAM表的寫操作,則會阻塞其他用戶對同一表的讀和寫操作;

MyISAM表的讀操作與寫操作之間,以及寫操作之間是串行的。當一個線程獲得對一個表的寫鎖后,只有持有鎖的線程可以對表進行更新操作。其他線程的讀、寫操作都會等待,直到鎖被釋放為止。

 

2.如何加表鎖

MyISAM在執行查詢語句(SELECT)前,會自動給涉及的所有表加讀鎖,在執行更新操作(UPDATE、DELETE、INSERT等)前,會自動給涉及的表加寫鎖,這個過程并不需要用戶干預,因此用戶一般不需要直接用LOCK TABLE命令給MyISAM表顯式加鎖。顯式加鎖基本上都是為了方便而已,并非必須如此。給MyISAM表顯示加鎖,一般是為了一定程度模擬事務操作,實現對某一時間點多個表的一致性讀取。例如,有一個訂單表orders,其中記錄有訂單的總金額total,同時還有一個訂單明細表order_detail,其中記錄有訂單每一產品的金額小計subtotal,假設我們需要檢查這兩個表的金額合計是否相等,可能就需要執行如下兩條SQL:SELECT SUM(total) FROM orders;

SELECT SUM(subtotal) FROM order_detail;

這時,如果不先給這兩個表加鎖,就可能產生錯誤的結果,因為第一條語句執行過程中,order_detail表可能已經發生了改變。因此,正確的方法應該是:

LOCK tables orders read local,order_detail read local;

SELECT SUM(total) FROM orders;

SELECT SUM(subtotal) FROM order_detail;

Unlock tables;

 

3.MyISAM表鎖優化建議

對于MyISAM存儲引擎,雖然使用表級鎖定在鎖定實現的過程中比實現行級鎖定或者頁級鎖所帶來的附加成本都要小,鎖定本身所消耗的資源也是最少。但是由于鎖定的顆粒度比較到,所以造成鎖定資源的爭用情況也會比其他的鎖定級別都要多,從而在較大程度上會降低并發處理能力。所以,在優化MyISAM存儲引擎鎖定問題的時候,最關鍵的就是如何讓其提高并發度。由于鎖定級別是不可能改變的了,所以我們首先需要盡可能讓鎖定的時間變短,然后就是讓可能并發進行的操作盡可能的并發。

 

從上面對MySQL表鎖的描述我們不難看出,表鎖具有開銷小,加鎖快的特性,而且不會出現死鎖,鎖定粒度大,發生鎖沖突的概率最高,并發度低。當然,表鎖只是MySQL里面的一種大的鎖的類別,還有行鎖。想要了解行鎖的小伙伴,鎖定本站的MySQL教程,里面有著詳細的講解。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 国产在线综合网 | 亚洲最大在线 | 精彩视频一区二区 | 久操免费在线 | 四虎永久在线观看视频精品 | 国产午夜精品尤物福利视频 | 欧美亚洲另类久久综合 | 九九99热久久精品在线9 | 国产精品自拍视频 | 天天操夜夜操美女 | 日本高清中文字幕一区二区三区a | 亚洲人成依人成综合网 | 久久爱.www| 亚洲美女视频网站 | 国产精品视频第一页 | 天天做天天添天天谢 | 久久96精品国产 | 色国产精品一区在线观看 | 欧美一级毛片久久精品 | 免费播放欧美毛片 | 国产一久久香蕉国产线看观看 | 亚洲精品乱码久久久久久麻豆 | 国产精品1区2区3区在线播放 | 久久社区视频 | 中文字幕日本精品一区二区三区 | 国产一区二区精品久久91 | 天天综合在线观看 | 国产成人精品免费视频大 | 最新香蕉97超级碰碰碰碰碰久 | 国产精品青草久久福利不卡 | 久久精品国产一区二区 | 亚洲夜色 | 伊人久久久 | 午夜影院免费体验区 | 日韩欧美中文字幕出 | 中文字幕专区 | 色欧美在线 | 久久www免费人成精品香蕉 | 男人的天堂在线视频 | 91香蕉福利一区二区三区 | 中文字幕天天躁夜夜狠狠综合 |