MySQL 中提供了兩種并發控制機制,悲觀鎖和樂觀鎖。其中悲觀鎖是指在操作數據時,認為數據會被其他并發線程修改,因此會在操作之前先加鎖。而樂觀鎖則是在操作數據時不加鎖,而是在提交操作時檢查該數據是否被其他線程修改。下面我們將分別介紹一下這兩種鎖的使用實例。
1. 悲觀鎖實例
-- 創建一個測試表,包含 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 字段加悲觀鎖,保證了其他線程不能對該字段進行修改,然后再對該字段進行更新操作。
2. 樂觀鎖實例
-- 創建一個測試表,包含 id 和 count 兩個字段 CREATE TABLE test ( id INT PRIMARY KEY, count INT ); -- 在更新 count 字段之前,檢查其是否被其他線程修改 BEGIN; SELECT count FROM test WHERE id = 1; // 對 count 字段進行更新操作 UPDATE test SET count = count + 1 WHERE id = 1 AND count = 當前值; COMMIT;
在上面的實例中,我們使用了 SELECT … 語句來查詢 count 字段的當前值,然后再對該字段進行更新操作。但是,在更新操作之前,我們會再次查詢 count 字段的當前值,如果此時該值已經被其他線程修改,則更新操作會被取消。這就是樂觀鎖的實現原理。
上一篇mysql恢復默認設置
下一篇css文字靠近底部