MySQL提供了四個不同的事務級別用于控制并發事務的行為。事務級別決定了在并發環境中事務的隔離程度。MySQL 的四個事務級別分別為:未提交讀(Read Uncommitted)、提交讀(Read Committed)、可重復讀(Repeatable Read)和串行化(Serializable)。
未提交讀(Read Uncommitted)事務級別允許一個事務讀取另一個事務未提交的數據。在該級別下,一個事務可以讀取到另一個事務已經修改但還未提交的數據,因此存在臟讀取(Dirty Read)的可能性。
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
提交讀(Read Committed)事務級別是 MySQL 的默認事務級別。在該級別下,一個事務只能讀取另一個事務已經提交的數據,沒有臟讀取的情況。但是,如果另一個事務正在執行修改操作,則當前事務需要等待該事務提交之后才能讀取到最新數據。
SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
可重復讀(Repeatable Read)事務級別保證在一個事務內多次讀取同一個數據時,其返回結果相同。在該級別下,如果一個事務已經讀取了某個數據,其他事務在該事務提交之前不可對該數據進行修改。但是,該級別下仍然存在幻讀(Phantom Read)的情況,即一個事務在同一條件下多次執行同一查詢,但是查詢結果卻不相同,因為另一個事務已經向表中插入了新數據。
SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
串行化(Serializable)事務級別是最高的事務級別。它會對讀取和寫入操作進行加鎖,保證在多個事務并發執行時,結果是和串行執行結果相同的。在該級別下,可以避免幻讀,但是會影響并發性能。
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;