在MySQL中,樂觀鎖和悲觀鎖是兩種常見的并發控制方式。樂觀鎖相對于悲觀鎖,具有更高的并發性和性能,但也需要更多的開發工作。下面分別介紹樂觀鎖和悲觀鎖的具體實現。
樂觀鎖指的是,在并發情況下,每個事務都假設其他事務不會干擾,因此先進行操作,再去檢驗。在MySQL中,可以通過版本號來實現樂觀鎖。在每個表中,可以定義一個版本號列,對于每個更新操作,會將版本號+1,如果版本號不匹配,則表示當前數據被其他事務修改,此次操作失敗。示例代碼如下:
BEGIN; SELECT version FROM table WHERE id=1; #假設上一步返回的版本號為1,執行以下操作 UPDATE table SET column='newvalue',version=2 WHERE id=1 AND version=1; #如果返回的行數不為1,則說明版本號已被其他事務修改,執行ROLLBACK操作 COMMIT;
悲觀鎖指的是,在并發情況下,每個事務都假設其他事務會干擾,因此先進行鎖定操作,再進行操作。在MySQL中,可以通過SELECT ... FOR UPDATE語句來實現悲觀鎖。該語句會在選取需要更新的行后,立即對這些行進行排它鎖定,其他事務在這些行上進行操作時,都需要等待,直到當前事務提交或回滾。示例代碼如下:
BEGIN; SELECT * FROM table WHERE id=1 FOR UPDATE; #對返回的行進行操作 UPDATE table SET column='newvalue' WHERE id=1; COMMIT;