行级锁
InnoDB行鎖是通過給索引上的索引項加鎖來實現的。所以,只有通過索引條件檢索數據,InnoDB才使用行級鎖,否則,InnoDB將使用表鎖。其他注意事項:
- 在不通過索引條件查詢的時候,InnoDB使用的是表鎖,而不是行鎖。
- 由于MySQL的行鎖是針對索引加的鎖,不是針對記錄加的鎖,所以即使是訪問不同行的記錄,如果使用了相同的索引鍵,也是會出現鎖沖突的。
- 當表有多個索引的時候,不同的事務可以使用不同的索引鎖定不同的行,另外,不論是使用主鍵索引、唯一索引或普通索引,InnoDB都會使用行鎖來對數據加鎖。
- 即便在條件中使用了索引字段,但具體是否使用索引來檢索數據是由MySQL通過判斷不同執行計劃的代價來決定的,如果MySQL認為全表掃描效率更高,比如對一些很小的表,它就不會使用索引,這種情況下InnoDB將使用表鎖,而不是行鎖。因此,在分析鎖沖突時,別忘了檢查SQL的執行計劃,以確認是否真正使用了索引。
隱式加鎖:
InnoDB自動加意向鎖。
對于UPDATE、DELETE和INSERT語句,InnoDB會自動給涉及數據集加排他鎖(X);
對于普通SELECT語句,InnoDB不會加任何鎖;
顯示加鎖:
共享鎖(S):SELECT * FROM table_name WHERE ... LOCK IN SHARE MODE
排他鎖(X) :SELECT * FROM table_name WHERE ... FOR UPDATE
?
總結
- 上一篇: 为什么不要使用长事务
- 下一篇: 可重复读:为什么你改了我看不到呢?