Transactie-isolatieniveaus

Transacties en foutafhandeling in SQL Server

Miriam Antona

Software Engineer

Wat is concurrency?

Concurrency: twee of meer transacties die tegelijk gedeelde data lezen/wijzigen.

Isoleer onze transactie van andere transacties

Transacties en foutafhandeling in SQL Server

Transactie-isolatieniveaus

  • READ COMMITTED (standaard)
  • READ UNCOMMITTED
  • REPEATABLE READ
  • SERIALIZABLE
  • SNAPSHOT
SET TRANSACTION ISOLATION LEVEL 
    {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE | SNAPSHOT}
Transacties en foutafhandeling in SQL Server

Huidig isolatieniveau bekijken

SELECT CASE transaction_isolation_level 
    WHEN 0 THEN 'UNSPECIFIED' 
    WHEN 1 THEN 'READ UNCOMMITTED' 
    WHEN 2 THEN 'READ COMMITTED' 
    WHEN 3 THEN 'REPEATABLE READ ' 
    WHEN 4 THEN 'SERIALIZABLE' 
    WHEN 5 THEN 'SNAPSHOT' 
END AS transaction_isolation_level 
FROM sys.dm_exec_sessions 
WHERE session_id = @@SPID
| transaction_isolation_level |
|-----------------------------|
| READ COMMITTED              |
Transacties en foutafhandeling in SQL Server

READ UNCOMMITTED

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
  • Minst restrictieve isolatieniveau
  • Lees rijen gewijzigd door een andere transactie die nog niet is gecommit of teruggedraaid
Transacties en foutafhandeling in SQL Server

READ UNCOMMITTED

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
  • Minst restrictieve isolatieniveau
  • Lees rijen gewijzigd door andere transacties zonder dat ze gecommit/teruggedraaid zijn.
Dirty reads Non-repeatable reads Phantom reads
READ UNCOMMITTED ja ja ja
Transacties en foutafhandeling in SQL Server

Dirty reads

Oorspronkelijk saldo rekening 5 = $35.000

Transactie1

BEGIN TRAN
  UPDATE accounts
  SET current_balance = 30000
  WHERE account_id = 5;

ROLLBACK TRAN;

Transactie2

...

...

...

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
SELECT current_balance
FROM accounts WHERE account_id = 5;
| current_balance |
|-----------------|
| 30000,00        |
Transacties en foutafhandeling in SQL Server

Non-repeatable reads

Transactie1

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
BEGIN TRAN
    SELECT * FROM accounts WHERE account_id = 5;
| current_balance |
|-----------------|
| 35000,00        |

Transactie2

...

...

BEGIN TRAN
    UPDATE accounts
    SET current_balance = 30000 WHERE account_id = 5;
COMMIT TRAN
Transacties en foutafhandeling in SQL Server

Non-repeatable reads

Transactie1

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
BEGIN TRAN
    SELECT * FROM accounts WHERE account_id = 5;
| current_balance |
|-----------------|
| 35000,00        |
    SELECT * FROM accounts WHERE account_id = 5;
| current_balance |
|-----------------|
| 30000,00        |

Transactie2

...

...

BEGIN TRAN
    UPDATE accounts
    SET current_balance = 30000 WHERE account_id = 5;
COMMIT TRAN
Transacties en foutafhandeling in SQL Server

Phantom reads

Transactie1

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
BEGIN TRAN
SELECT * FROM accounts
    WHERE current_balance BETWEEN 45000 AND 50000
| account_number       | ... | current_balance |
|----------------------|-----|-----------------|
| 55555555552020202020 | ... | 50000,00        |

Transactie2

...

...

BEGIN TRAN
INSERT INTO accounts
    VALUES ('55555555553939393939', 1, 45000)
COMMIT TRAN
Transacties en foutafhandeling in SQL Server

Phantom reads

Transactie1

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
BEGIN TRAN
SELECT * FROM accounts 
    WHERE current_balance BETWEEN 45000 AND 50000
| account_number       | ... | current_balance |
|----------------------|-----|-----------------|
| 55555555552020202020 | ... | 50000,00        | 
SELECT * FROM accounts 
    WHERE current_balance BETWEEN 45000 AND 50000
| account_number       |...| current_balance |
|----------------------|---|-----------------|
| 55555555553939393939 |...| 45000,00        | Phantom!
| 55555555552020202020 |...| 50000,00        |

Transactie2

...

...

BEGIN TRAN
INSERT INTO accounts
    VALUES ('55555555553939393939', 1, 45000)
COMMIT TRAN
Transacties en foutafhandeling in SQL Server

READ UNCOMMITTED - samenvatting

Voordelen:

  • Kan sneller zijn, blokkeert andere transacties niet.

Nadelen:

  • Laat dirty reads, non-repeatable reads en phantom reads toe.

Wanneer gebruiken?:

  • Je wilt niet geblokkeerd worden en accepteert concurrency-fenomenen.
  • Je wilt expliciet onvoltooide data lezen.
Transacties en foutafhandeling in SQL Server

Laten we oefenen!

Transacties en foutafhandeling in SQL Server

Preparing Video For Download...