İşlem izolasyon düzeyleri

SQL Server'da İşlemler ve Hata Yönetimi

Miriam Antona

Software Engineer

Eşzamanlılık nedir?

Eşzamanlılık: aynı anda paylaşılan veriyi okuyan/değiştiren iki veya daha fazla işlem.

İşlemi diğer işlemlerden yalıtma

SQL Server'da İşlemler ve Hata Yönetimi

İşlem izolasyon düzeyleri

  • READ COMMITTED (varsayılan)
  • READ UNCOMMITTED
  • REPEATABLE READ
  • SERIALIZABLE
  • SNAPSHOT
SET TRANSACTION ISOLATION LEVEL 
    {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE | SNAPSHOT}
SQL Server'da İşlemler ve Hata Yönetimi

Geçerli izolasyon düzeyini öğrenme

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              |
SQL Server'da İşlemler ve Hata Yönetimi

READ UNCOMMITTED

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
  • En az kısıtlayıcı izolasyon düzeyi
  • Başka bir işlemin henüz commit/rollback etmediği satırları okuyabilir
SQL Server'da İşlemler ve Hata Yönetimi

READ UNCOMMITTED

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
  • En az kısıtlayıcı izolasyon düzeyi
  • Diğer işlemlerce değiştirilmiş satırları commit/rollback olmadan okuyabilir.
Kirli okumalar Tekrarlanamayan okumalar Hayalet okumalar
READ UNCOMMITTED evet evet evet
SQL Server'da İşlemler ve Hata Yönetimi

Kirli okumalar

Hesap 5’in ilk bakiyesi = $35.000

İşlem1

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

ROLLBACK TRAN;

İşlem2

...

...

...

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
SELECT current_balance
FROM accounts WHERE account_id = 5;
| current_balance |
|-----------------|
| 30000,00        |
SQL Server'da İşlemler ve Hata Yönetimi

Tekrarlanamayan okumalar

İşlem1

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

İşlem2

...

...

BEGIN TRAN
    UPDATE accounts
    SET current_balance = 30000 WHERE account_id = 5;
COMMIT TRAN
SQL Server'da İşlemler ve Hata Yönetimi

Tekrarlanamayan okumalar

İşlem1

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        |

İşlem2

...

...

BEGIN TRAN
    UPDATE accounts
    SET current_balance = 30000 WHERE account_id = 5;
COMMIT TRAN
SQL Server'da İşlemler ve Hata Yönetimi

Hayalet okumalar

İşlem1

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        |

İşlem2

...

...

BEGIN TRAN
INSERT INTO accounts
    VALUES ('55555555553939393939', 1, 45000)
COMMIT TRAN
SQL Server'da İşlemler ve Hata Yönetimi

Hayalet okumalar

İşlem1

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        | Hayalet!
| 55555555552020202020 |...| 50000,00        |

İşlem2

...

...

BEGIN TRAN
INSERT INTO accounts
    VALUES ('55555555553939393939', 1, 45000)
COMMIT TRAN
SQL Server'da İşlemler ve Hata Yönetimi

READ UNCOMMITTED - özet

Artıları:

  • Daha hızlı olabilir, diğer işlemleri engellemez.

Eksileri:

  • Kirli, tekrarlanamayan ve hayalet okumalara izin verir.

Ne zaman kullanılır?:

  • Engellenmek istemiyorsanız ve eşzamanlılık olgularını dert etmiyorsanız.
  • Onaylanmamış veriyi özellikle görmek istiyorsanız.
SQL Server'da İşlemler ve Hata Yönetimi

Hadi pratik yapalım!

SQL Server'da İşlemler ve Hata Yönetimi

Preparing Video For Download...