將一張表的數據insert 到另一個表,mysql從一個表查詢插入另一個表存在時更新_漫談MySQL的鎖機制

 2023-12-12 阅读 28 评论 0

摘要:1 MySQL的三種鎖1.1 表鎖開銷小,加鎖快不會出現死鎖鎖定粒度大,發生鎖沖突的概率最高,并發度最低1.2 行鎖開銷大,加鎖慢會出現死鎖鎖定粒度小,發生鎖沖突的概率最低,并發度最高1.3 頁鎖開銷和加鎖時間介于表鎖和行鎖之間會出現死鎖
6386f871effbfda05d1e2b24c6aa86a8.png

1 MySQL的三種鎖

1.1 表鎖

  • 開銷小,加鎖快
  • 不會出現死鎖
  • 鎖定粒度大,發生鎖沖突的概率最高,并發度最低

1.2 行鎖

  • 開銷大,加鎖慢
  • 會出現死鎖
  • 鎖定粒度小,發生鎖沖突的概率最低,并發度最高

1.3 頁鎖

  • 開銷和加鎖時間介于表鎖和行鎖之間
  • 會出現死鎖
  • 鎖定粒度介于表鎖和行鎖之間,并發度一般

1.4 引擎與鎖

  • MyISAM和MEMORY支持表鎖
  • BDB支持頁鎖,也支持表鎖
  • Innodb既支持行鎖,也支持表鎖,默認行鎖

將一張表的數據insert 到另一個表、1.5 查詢表鎖爭用情況

檢查table_locks_waited和table_locks_immediate狀態變量分析

  • table_locks_immediate : 可以立即獲取鎖的次數
  • table_locks_waited : 不能立即獲取鎖,需要等待鎖的次數
2353eb9da9e5f39398ac38d6b72f2a34.png
4e7ca8e6e6dc673449f3d6f209822e2b.png

table_locks_waited 的值越高,則說明存在嚴重的表級鎖的爭用情況

2 表鎖模式(MyISAM)

MySQL的表鎖有兩種模式

  • 表共享讀鎖(Table Read Lock)
  • 表獨占寫鎖(Table Write Lock)

2.1 表鎖兼容性

sql根據一個表更新另一個表?鎖模式的兼容如下表

是否兼容請求none請求讀鎖請求寫鎖當前處于讀鎖是是否當前處于寫鎖是否否

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

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

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

將一個表的字段更新到另一個表、2.2 如何加表鎖

對于 MyISAM 引擎

  • 執行select前,會自動給涉及的所有表加 讀
  • 執行更新(update,delete,insert)會自動給涉及到的表加 寫

不需要用戶直接顯式用lock table命令

對于給MyISAM顯式加鎖,一般是為了在一定程度上模擬事務操作,實現對某一個時間點多個表一致性讀取

2.2.1 實例

  • 訂單表 - orders 記錄各訂單的總金額total
  • 訂單明細表 - order_detail 記錄各訂單每一產品的金額小計subtotal

mysql查詢是否存在。假設我們需要檢查這兩個表的金額合計是否相符,可能就需要執行如下兩條SQL

圖片上傳失敗...(image-3017e3-1547370332969)

這時,如果不先給這兩個表加鎖,就可能產生錯誤的結果;

因為第一條語句執行過程中,order_detail表可能已經發生了改變.

因此,正確寫法應該如下

oracle從一個表查數據插到另一張表,圖片上傳失敗...(image-8081d7-1547370332969)

2.2.2 注意點

  • 上面的例子在LOCK TABLES時加了‘local’選項,其作用就是在滿足MyISAM表并發插入條件的情況下,允許其他用戶在表尾插入記錄
  • 在用LOCK TABLES給表顯式加表鎖時,必須同時取得所有涉及表的鎖,并且MySQL支持鎖升級; 也就是說,在執行LOCK TABLES后,只能訪問顯式加鎖的這些表,不能訪問未加鎖的表; 同時,如果加的是讀鎖,那么只能執行查詢操作,而不能執行更新操作 其實,在自動加鎖的情況下也基本如此,MySQL會一次獲得SQL語句所需要的全部鎖.這也正是MyISAM表不會出現死鎖(Deadlock Free)的原因

session1session2獲得表 film_text 的讀鎖 lock table film_text read;?可select * from film_text可select * from film_text不能查詢沒有鎖定的表 :select * from film可查詢/更新未鎖定的表: select * from film插入或更新鎖定表會提示錯誤 update...from film_text更新鎖定表會等待 update...from film_text釋放鎖 unlock tables等待?獲得鎖,更新成功

##2.3 tips

當使用lock tables時,不僅需要一次鎖定用到的所有表

mysql數據庫的調優和部署,且同一表在SQL語句中出現多少次,就要通過與SQL語句中別名鎖多少次

lock table actor read

會提示錯誤

select a.first_name.....

需要對別名分別鎖定

lock table actor as a read,actor as b read;

3 MyISAM的并發鎖

在一定條件下,MyISAM也支持并發插入和讀取

3.1 系統變量 : concurrent_insert

控制其并發插入的行為,其值分別可以為

  • 0 不允許并發插入,所有插入對表加互斥鎖
  • 1 只要表中無空洞,就允許并發插入. MyISAM允許在一個讀表的同時,另一個進程從表尾插入記錄(MySQL的默認設置)
  • 2 無論MyISAM表中有無空洞,都強制在表尾并發插入記錄 若無讀線程,新行插入空洞中

可以利用MyISAM的并發插入特性,來解決應用中對同表查詢和插入的鎖爭用

例如,將concurrent_insert系統變量設為2,總是允許并發插入;

同時,通過定期在系統空閑時段執行OPTIONMIZE TABLE語句來整理空間碎片,收到因刪除記錄而產生的中間空洞

刪除操作不會重整整個表,只是把 行 標記為刪除,在表中留下空洞

MyISAM傾向于在可能時填滿這些空洞,插入時就會重用這些空間,無空洞則把新行插到表尾

3.2 MyISAM的鎖調度

MyISAM的讀和寫鎖互斥,讀操作串行的

  • 一個進程請求某個MyISAM表的讀鎖,同時另一個進程也請求同表的寫鎖,MySQL如何處理呢? 寫進程先獲得鎖!!! 不僅如此,即使讀進程先請求先到鎖等待隊列,寫請求后到,寫鎖也會插到讀請求之前!!!

這是因為MySQL認為寫請求一般比讀請求重要

這也正是MyISAM表不適合有大量更新 / 查詢操作應用的原因

大量的更新操作會造成查詢操作很難獲得讀鎖,從而可能永遠阻塞

幸好,我們可以通過一些設置來調節MyISAM的調度行為

  • 指定啟動參數low-priority-updates 使MyISAM引擎默認給予讀請求以優先權利
  • 執行命令SET LOW_PRIORITY_UPDATES=1 使該連接發出的更新請求優先級降低
  • 指定INSERT、UPDATE、DELETE語句的LOW_PRIORITY屬性 降低該語句的優先級

雖然上面3種方法都是要么更新優先,要么查詢優先,但還是可以用其來解決查詢相對重要的應用(如用戶登錄系統)中,讀鎖等待嚴重的問題

另外,MySQL也提供了一種折中的辦法來調節讀寫沖突;

即給系統參數max_write_lock_count設置一個合適的值;

當一個表的讀鎖達到這個值后,MySQL便暫時將寫請求的優先級降低,給讀進程一定獲得鎖的機會

* * *

4 InnoDB鎖

InnoDB與MyISAM的最大不同有兩點

  • 支持事務
  • 采用行鎖

行級鎖和表級鎖本來就有許多不同之處,另外,事務的引入也帶來了一些新問題

4.1 事務

一組SQL語句組成的邏輯處理單元

  • 原子性(Actomicity) 事務是一個原子操作單元,其對數據的修改,要么全都執行,要么全都不執行
  • 一致性(Consistent) 在事務開始和完成時,數據都必須保持一致狀態 這意味著所有相關的數據規則都必須應用于事務的修改,以保持完整性 事務結束時,所有的內部數據結構(如B樹索引或雙向鏈表)也都必須是正確的
  • 隔離性(Isolation) 一個事務所做的修改在最終提交前對其他事務不可見
  • 持久性(Durability) 一旦事務提交,它對于數據的修改會持久化到DB

4.2 事務的問題

相對于串行處理來說,并發事務處理能大大增加數據庫資源的利用率,提高數據庫系統的事務吞吐量,從而可以支持可以支持更多的用戶

但并發事務處理也會帶來一些問題,主要包括以下幾種情況

  • 更新丟失(Lost Update) 當多個事務選擇同一行,然后基于最初選定值更新該行時,由于事務隔離性,最后的更新覆蓋了其他事務所做的更新. 例如,兩個編輯人員制作了同一文檔的電子副本。每個編輯人員獨立地更改其副本,然后保存更改后的副本,這樣就覆蓋了原始文檔。最后保存其更改保存其更改副本的編輯人員覆蓋另一個編輯人員所做的修改; 如果在一個編輯人員完成并提交事務之前,另一個編輯人員不能訪問同一文件,則可避免此問題
  • 臟讀(Dirty Reads) 一個事務正在對一條記錄做修改,在該事務提交前,這條記錄的數據就處于不一致狀態 這時,另一個事務也來讀取同一條記錄,讀取了這些未提交的數據
  • 不可重復讀(Non-Repeatable Reads) 一個事務在讀取某些數據已經發生了改變、或某些記錄已經被刪除
  • 幻讀(Phantom Reads) 一個事務按相同的查詢條件重新讀取以前檢索過的數據,卻發現其他事務插入了滿足其查詢條件的新數據

4.3 事務隔離級別

在并發事務的問題中,“更新丟失”通常應該是完全避免的;

但防止更新丟失,并不能單靠數據庫事務控制器來解決,需要應用程序對要更新的數據加必要的鎖來解決,因此,防止更新丟失應該是應用的責任

“臟讀”、“不可重復讀”和“幻讀”,其實都是數據庫讀一致性問題,必須由數據庫提供一定的事務隔離機制來解決

數據庫實現事務隔離的方式,基本可以分為以下兩種

  • 在讀取數據前,對其加鎖,防止其他事務對數據進行修改
  • 不加任何鎖,通過一定機制生成一個數據請求時間點的一致性數據快照,并用這個快照來提供一定級別(語句級或事務級)的一致性讀取. 從用戶的角度,好像是數據庫可以提供同一數據的多個版本,因此,這種技術叫做數據多版本并發控制(MultiVersion Concurrency Control,MVCC),也經常稱為多版本數據庫

數據庫的事務隔離級別越嚴格,并發副作用越小,但付出的代價也越大

因為事務隔離實質上就是使事務在一定程度上“串行化”進行,這顯然與“并發”矛盾

為了解決“隔離”與“并發”的矛盾,ANSI SQL定義了4種隔離級別

隔離級別/讀數據一致性及允許的并發副作用讀數據一致性臟讀不可重復讀幻讀未提交讀(Read uncommitted)最低級別,只能保證不讀取物理上損壞的數據是是是已提交度(Read committed)語句級否是是可重復讀(Repeatable read)事務級否否是可序列化(Serializable)最高級別,事務級否否否

查看Innodb行鎖爭用情況

5b4b59c4a1aea25ae9add02e56b842f5.png
c44a9d4ae3b158589dfd47b6f0c92ca0.png

如果發現爭用比較嚴重,如Innodb_row_lock_waits和Innodb_row_lock_time_avg的值比較高

查詢information_schema相關表來查看鎖情況

27a7ac5951674caf2c80dac78827ab23.png
870e34e2a8c5ad5cecd61ef4a68a43fe.png
e60203b438927783c0806d4c66d23c12.png

設置Innodb monitors

進一步觀察發生鎖沖突的表,數據行等,并分析鎖爭用的原因

b0daaa1ac72a2df45523ebc8e26b9820.png
d9c0784892becf9cf8fbb7e09a472d7b.png

停止監視器

03dd79a8d0bee1bf3e584b9a764befde.png

默認情況每15秒會向日志中記錄監控的內容;

如果長時間打開會導致.err文件變得非常巨大;

所以確認原因后,要刪除監控表關閉監視器,或者通過使用--console選項來啟動服務器以關閉寫日志功能

4.4 InnoDB的行鎖

InnoDB支持以下兩種類型的行鎖

  • 共享鎖(讀鎖S) 若事務 T 對數據對象 A 加了 S 鎖; 則事務 T 可以讀 A 但不能修改 A; 其它事務只能再對它加 S 鎖,而不能加 X 鎖,直到 T 釋放 A 上的 S 鎖; 這保證了,其他事務可以讀 A,但在事務 T 釋放 S 鎖之前,不能對 A 做任何修改操作.
  • 排他鎖(寫鎖X) 若事務 T 對數據對象A加 X 鎖; 事務 T 可以讀 A 也可以修改 A; 其他事務不能對 A 加任何鎖,直到 T 釋放 A 上的鎖; 這保證了,其他事務在 T 釋放 A 上的鎖之前不能再讀取和修改 A .

MySQL InnoDB默認行級鎖

行級鎖都是基于索引的,若一條SQL語句用不到索引是不會使用行級鎖的,會使用表級鎖把整張表鎖住

為了允許行/表鎖共存,實現多粒度鎖機制,InnoDB還有兩種內部使用的意向鎖(Intention Locks)

這兩種意向鎖都是表鎖

  • 意向共享鎖(IS) 事務打算給數據行共享鎖; 事務在給一個數據行加共享鎖前必須先取得該表的IS鎖
  • 意向排他鎖(IX) 事務打算給數據行加排他鎖; 事務在給一個數據行加排他鎖前必須先取得該表的IX鎖

當前鎖/是否兼容/請求鎖XIXSISX沖突沖突沖突沖突IX沖突兼容沖突兼容S沖突沖突兼容兼容IS沖突兼容兼容兼容

如果一個事務請求的鎖模式與當前鎖兼容,InnoDB就請求的鎖授予該事務;

反之,如果兩者兩者不兼容,該事務就要等待鎖釋放

意向鎖是InnoDB自動加的,不需用戶干預.

對于UPDATE、DELETE和INSERT語句,InnoDB會自動給涉及及數據集加排他鎖(X);

對于普通SELECT語句,InnoDB不會加任何鎖.

對于SELECT語句,可以通過以下語句顯式地給記錄加讀/寫鎖

  • 共享鎖(S)
9351ed52a5df278859fea20467eca18b.png
  • 排他鎖(X)
f9301d1e33f97f5f6d8410cfd9e5ff0f.png

共享鎖語句主要用在需要數據依存關系時確認某行記錄是否存在;

并確保沒有人對這個記錄UPDATE或DELETE.

但如果當前事務也需要對該記錄進行更新,則很有可能造成死鎖;

對于鎖定行記錄后需要進行更新操作的應用,應該使用排他鎖語句.

4.5 實例

4.5.1 Innodb共享鎖

session_1session_2set autocommit=0,select * from actor where id =1set autocommit=0,select * from actor where id =1當前seesion對id為1的記錄加入共享鎖 select * from actor where id =1 lock in share mode??其他seesion仍然可以查詢,并對該記錄加入 select * from actor where id =1 lock in share mode當前session對鎖定的記錄進行更新,等待鎖 update。。。where id=1??當前session對鎖定記錄進行更新,則會導致死鎖退出 update。。。where id=1

| 獲得鎖,更新成功 |

4.5.2 Innodb排他鎖

session_1session_2set autocommit=0,select * from actor where id =1set autocommit=0,select * from actor where id =1當前seesion對id為1的記錄加入for update 共享鎖 select * from actor where id =1 for update??可查詢該記錄select from actor where id =1,但是不能再記錄共享鎖,會等待獲得鎖select from actor where id =1 for update更新后釋放鎖 update。。。 commit??其他session,獲得鎖,得到其他seesion提交的記錄

4.6 行鎖的實現

行鎖是通過給索引上的索引項加鎖來實現

如果沒有索引,InnoDB將通過隱藏的聚簇索引來對記錄加鎖

  • Record Locks:對索引項加鎖
  • Gap lock:對索引項之的“間隙“,第一條記錄前的”間隙“,或最后一條記錄后的”間隙“,加鎖
  • Next-key lock:前兩種的組合,對記錄及其前面的間隙加鎖

行鎖實現特點意味著:

如果不通過索引條件檢索數據,那么Innodb將對表的所有記錄加鎖,和表鎖一樣

間隙鎖(Next-Key鎖)

當我們用范圍條件而不是相等條件檢索數據,并請求共享或排他鎖時,InnoDB會給符合條件的已有數據的索引項加鎖;

對于鍵值在條件范圍內但并不存在的記錄,叫做“間隙(GAP)”,InnoDB也會對這個“間隙”加鎖,這種鎖機制就是所謂的間隙鎖(Next-Key鎖).

舉例來說,假如emp表中只有101條記錄,其empid的值分別是1,2,...,100,101,下面的SQL:

InnoDB 不僅會對符合條件的 empid 值為 101 的記錄加鎖;

也會對 empid大于101(這些記錄并不存在)的“間隙”加鎖

ada3d6ffafe2324add2eaec723be735f.png

間隙鎖的目的

  • 防止幻讀,以滿足相關隔離級別的要求 對于上例,若不使用間隙鎖,如果其他事務插入 empid 大于 100 的任何記錄,; 那么本事務如果再次執行上述語句,就會發生幻讀
  • 滿足其恢復和復制的需要 在使用范圍條件檢索并鎖定記錄時; InnoDB 這種加鎖機制會阻塞符合條件范圍內鍵值的并發插入,這往往會造成嚴重的鎖等待; 因此,在實際開發中,尤其是并發插入較多的應用; 我們要盡量優化業務邏輯,盡量使用相等條件來訪問更新數據,避免使用范圍條件.

4.7 when 使用表鎖

對于InnoDB,在絕大部分情況下都應該使用行鎖

因為事務,行鎖往往是我們選擇InnoDB的理由

但在個別特殊事務中,也可以考慮使用表鎖

  • 事務需要更新大部分數據,表又較大 若使用默認的行鎖,不僅該事務執行效率低(因為需要對較多行加鎖,加鎖是需要耗時的); 而且可能造成其他事務長時間鎖等待和鎖沖突; 這種情況下可以考慮使用表鎖來提高該事務的執行速度
  • 事務涉及多個表,較復雜,很可能引起死鎖,造成大量事務回滾 這種情況也可以考慮一次性鎖定事務涉及的表,從而避免死鎖、減少數據庫因事務回滾帶來的開銷

當然,應用中這兩種事務不能太多,否則,就應該考慮使用MyISAM

在InnoDB下 ,使用表鎖要注意

  • 使用LOCK TALBES雖然可以給InnoDB加表鎖 表鎖不是由InnoDB引擎層管理的,而是由其上一層MySQL Server負責; 僅當autocommit=0、innodb_table_lock=1(默認設置),InnoDB 引擎層才知道MySQL加的表鎖,MySQL Server才能感知InnoDB加的行鎖; 這種情況下,InnoDB才能自動識別涉及表鎖的死鎖 否則,InnoDB將無法自動檢測并處理這種死鎖
  • 在用LOCK TALBES對InnoDB鎖時要注意,要將autocommit設為0,否則MySQL不會給表加鎖 事務結束前,不要用UNLOCK TALBES釋放表鎖,因為它會隱式地提交事務 COMMIT或ROLLBACK不能釋放用LOCK TALBES加的表鎖,必須用UNLOCK TABLES釋放表鎖,正確的方式見如下語句
  • 需要寫表t1并從表t讀
612e1ba3b6817f63b88c3147a9dd1492.png

5 死鎖

MyISAM表鎖是deadlock free的,這是因為MyISAM總是一次性獲得所需的全部鎖,要么全部滿足,要么等待,因此不會出現死鎖

但在InnoDB中,除單個SQL組成的事務外,鎖是逐步獲得的,這就決定了InnoDB發生死鎖是可能的

發生死鎖后,InnoDB一般都能自動檢測到,并使一個事務釋放鎖并退回,另一個事務獲得鎖,繼續完成事務

  • 但在涉及外部鎖,或涉及鎖的情況下,InnoDB并不能完全自動檢測到死鎖 這需要通過設置鎖等待超時參數innodb_lock_wait_timeout來解決 需要說明的是,這個參數并不是只用來解決死鎖問題,在并發訪問比較高的情況下,如果大量事務因無法立即獲取所需的鎖而掛起,會占用大量計算機資源,造成嚴重性能問題,甚至拖垮數據庫 我們通過設置合適的鎖等待超時閾值,可以避免這種情況發生。

通常來說,死鎖都是應用設計的問題,通過調整業務流程、數據庫對象設計、事務大小、以及訪問數據庫的SQL語句,絕大部分都可以避免

下面就通過實例來介紹幾種死鎖的常用方法。

  • 應用中,不同的程序會并發存取多個表 盡量約定以相同的順序訪問表
  • 程序批處理數據時 事先對數據排序,保證每個線程按固定的順序來處理記錄
  • 在事務中,要更新記錄 應直接申請排他鎖,而不應該先申請共享鎖
  • 在可重復讀下,如果兩個線程同時對相同條件記錄用SELECT...ROR UPDATE加排他寫鎖 在沒有符合該記錄情況下,兩個線程都會加鎖成功 程序發現記錄尚不存在,就試圖插入一條新記錄,如果兩個線程都這么做,就會出現死鎖 這種情況下,將隔離級別改成READ COMMITTED,就可以避免問題
  • 當隔離級別為READ COMMITED時,如果兩個線程都先執行SELECT...FOR UPDATE 判斷是否存在符合條件的記錄,沒有 -> 插入記錄; 此時,只有一個線程能插入成功,另一個線程會出現鎖等待. 當第1個線程提交后,第2個線程會因主鍵重出錯,但雖然這個線程出錯了,卻會獲得一個排他鎖!這時如果有第3個線程又來申請排他鎖,也會出現死鎖. 對于這種情況,可以直接做插入操作,然后再捕獲主鍵重異常,或者在遇到主鍵重錯誤時,總是執行ROLLBACK釋放獲得的排他鎖

如果出現死鎖,可以用SHOW INNODB STATUS命令來確定最后一個死鎖產生的原因和改進措施。

6 總結

6.1 MyISAM的表鎖

  • 共享讀鎖之間是兼容的,但共享讀鎖和排他寫鎖之間,以及排他寫鎖之間互斥,即讀寫串行
  • 在一定條件下,MyISAM允許查詢/插入并發,可利用這一點來解決應用中對同一表查詢/插入的鎖爭用問題
  • MyISAM默認的鎖調度機制是寫優先,這并不一定適合所有應用,用戶可以通過設置LOW_PRIPORITY_UPDATES參數或在INSERT、UPDATE、DELETE語句中指定LOW_PRIORITY選項來調節讀寫鎖的爭用
  • 由于表鎖的鎖定粒度大,讀寫又是串行的,因此如果更新操作較多,MyISAM表可能會出現嚴重的鎖等待,可以考慮采用InnoDB表來減少鎖沖突

6.2 對于InnoDB表

  • 行鎖基于索引實現 如果不通過索引訪問數據,InnoDB會使用表鎖
  • 間隙鎖機制及使用間隙鎖的原因
  • 不同的隔離級別下,InnoDB的鎖機制和一致性讀策略不同
  • MySQL的恢復和復制對InnoDB鎖機制和一致性讀策略也有較大影響
  • 鎖沖突甚至死鎖很難完全避免

7 索引與鎖

在了解InnoDB的鎖特性后,用戶可以通過設計和SQL調整等措施減少鎖沖突和死鎖

  • 盡量使用較低的隔離級別
  • 精心設計索引,并盡量使用索引訪問數據,使加鎖更精確,從而減少鎖沖突的機會。
c075eb30b280c8858f5396234043eb99.png
  • 選擇合理的事務大小,小事務發生鎖沖突的幾率也更小
  • 給記錄集顯式加鎖時,最好一次性請求足夠級別的鎖。比如要修改數據的話,最好直接申請排他鎖,而不是先申請共享鎖,修改時再請求排他鎖,這樣容易產生死鎖。
  • 不同的程序訪問一組表時,應盡量約定以相同的順序訪問各表,對一個表而言,盡可能以固定的順序存取表中的行。這樣可以大減少死鎖的機會。
  • 盡量用相等條件訪問數據,這樣可以避免間隙鎖對并發插入的影響。
  • 不要申請超過實際需要的鎖級別;除非必須,查詢時不要顯示加鎖。
  • 對于一些特定的事務,可以使用表鎖來提高處理速度或減少死鎖的可能
4fd6173b9f973678eab72717e75edd8e.png
4962f79a2192d52fb053af208779761a.png
d06f0e163596d3bb7991550ad257ef93.png
381acb0580c9a99143d19e7b96720288.png
543bbe8e5c6126069ffc1ddf5ecbc366.png

參考

MySQL中的鎖(表鎖、行鎖)

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/5/194513.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息