MYSQL中的鎖必知必會

2021-10-12 13:14:29 字數 722 閱讀 2193

行級鎖 表級鎖 頁面鎖

myisam和memory只採用了一種鎖那就是表級鎖

bdb儲存引擎支援表級鎖和頁級鎖,預設是頁級鎖。

innodb儲存引擎支援表級鎖和行級鎖,預設是行級鎖。

速記:四大引擎都支援表級鎖,有兩個只有一種鎖,剩下的都有兩種鎖且組合不相同,且預設的都不是表級鎖,記住innodb預設是行級鎖,自然而然剩下的bdb就能快速背出是行級鎖。

下面詳細來說這三大鎖機制。

行級鎖:

行級鎖是 mysql 中鎖定粒度最細的一種鎖,表示只針對當前操作的行進行加鎖。行級鎖分為共享鎖和排他鎖。

特點:加鎖開銷大,會出現死鎖,鎖定粒度最小,發生鎖衝突的概率最低,併發度最高。

頁級鎖:

頁級鎖是 mysql 中鎖定粒度介於行級鎖和表級鎖中間的一種鎖。採取了折衷的頁級鎖,一次鎖定相鄰的一組記錄。bdb 支援頁級鎖。

特點:開銷和加鎖時間界於表鎖和行鎖之間;會出現死鎖;鎖定粒度界於表鎖和行鎖之間,併發度一般。

表級鎖:

表級鎖是 mysql 中鎖定粒度最大的一種鎖,表示對當前操作的整張表加鎖,它實現簡單,資源消耗較少,被大部分 mysql 引擎支援。表級鎖定分為表共享讀鎖(共享鎖)與表獨佔寫鎖(排他鎖)。

開銷小,加鎖快;不會出現死鎖;鎖定粒度大,發出鎖衝突的概率最高,併發度最低。

mysql必知必會 mysql必知必會(四)

十四 理解子查詢 1 通過子查詢過濾 這本書在所有的章節都關連到了資料庫表,訂單資料是儲存在兩個表中,orders表儲存著 訂單號碼 顧客id和訂單日期。個人的訂單列表關連著orderitems表,訂單表沒有儲存顧客資訊,它只是儲存著顧客id,這實際的顧客資訊是儲存在customers表中。現在假設...

mysql的必知必會 mysql 必知必會 筆記

好久沒有寫了。1 show columns from table 等同於describe table顯示的是表的結構。而select from table 則顯示的是整個表中插入的資料。2 select distinct c1,c2 from table除非列不相同,否則所有行將被檢索出來,即不能對...

mysql必知必會

一周了,總想寫點什麼,有的時候進步真的很難在一周顯示出來,週三的時候,我跟我的領導說,好快啊,又週三了,不知不覺,他說是啊,現在對於他來說,有時候他過一天可能跟我過一周的感覺差不多,每天都在忙,時間過的特別快,也沒有感覺做出來點什麼,當然實際肯定是怎麼做了一些東西的,是否我以後也會如此呢?說說技術把...