MySQL 中提供了兩種并發(fā)控制機制,悲觀鎖和樂觀鎖。其中悲觀鎖是指在操作數(shù)據(jù)時,認(rèn)為數(shù)據(jù)會被其他并發(fā)線程修改,因此會在操作之前先加鎖。而樂觀鎖則是在操作數(shù)據(jù)時不加鎖,而是在提交操作時檢查該數(shù)據(jù)是否被其他線程修改。下面我們將分別介紹一下這兩種鎖的使用實例。
1. 悲觀鎖實例
-- 創(chuàng)建一個測試表,包含 id 和 name 兩個字段 CREATE TABLE test ( id INT PRIMARY KEY, name VARCHAR(50) ); -- 在 name 字段上加鎖,并更新該字段的值 BEGIN; SELECT name FROM test WHERE id = 1 FOR UPDATE; UPDATE test SET name = 'new name' WHERE id = 1; COMMIT;
在上面的實例中,我們使用了 SELECT … FOR UPDATE 語句來對 name 字段加悲觀鎖,保證了其他線程不能對該字段進(jìn)行修改,然后再對該字段進(jìn)行更新操作。
2. 樂觀鎖實例
-- 創(chuàng)建一個測試表,包含 id 和 count 兩個字段 CREATE TABLE test ( id INT PRIMARY KEY, count INT ); -- 在更新 count 字段之前,檢查其是否被其他線程修改 BEGIN; SELECT count FROM test WHERE id = 1; // 對 count 字段進(jìn)行更新操作 UPDATE test SET count = count + 1 WHERE id = 1 AND count = 當(dāng)前值; COMMIT;
在上面的實例中,我們使用了 SELECT … 語句來查詢 count 字段的當(dāng)前值,然后再對該字段進(jìn)行更新操作。但是,在更新操作之前,我們會再次查詢 count 字段的當(dāng)前值,如果此時該值已經(jīng)被其他線程修改,則更新操作會被取消。這就是樂觀鎖的實現(xiàn)原理。