MySQL是一款非常流行的關系型數據庫。在MySQL中,默認情況下每個事務都會自動加上行級行鎖(innodb行鎖)來保障數據的一致性和并發控制。行鎖就是在操作一行數據時,只會鎖定當前行,而不是其他行。
那么,在什么情況下會觸發MySQL的行鎖呢?
CREATE TABLE students (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(20),
age INT
);
假設我們有上述這個示例表,現在有兩個事務想要同時更新這個表中某一行的數據。由于每個事務都會為自己操作的行加上行鎖,這兩個事務會形成鎖沖突,其中一個事務必須等待另一個事務執行完成才能繼續進行。
-- 事務1
BEGIN;
UPDATE students SET age = 20 WHERE name = 'Tom';
-- 等待5秒
SELECT SLEEP(5);
COMMIT;
-- 事務2
BEGIN;
UPDATE students SET age = 30 WHERE name = 'Tom';
COMMIT;
上述的事務1會鎖定名字為Tom的這一行數據,同時等待完成的時間為5秒鐘。在這個過程中,如果事務2想要更新同一行的數據,就會被鎖住,必須等待事務1執行完成才能繼續操作。
除了上述示例中的鎖沖突情況外,還有一些其他情況也會觸發MySQL的行鎖。比如使用了索引進行更新、插入操作等。
在實際開發中,需要注意并發訪問時的事務處理和鎖優化,避免死鎖和性能下降。
下一篇html 設置下邊框