Transaksi dan Penanganan Kesalahan di SQL Server
Miriam Antona
Software Engineer
tempDBALTER DATABASE myDatabaseName SET ALLOW_SNAPSHOT_ISOLATION ON;
SET TRANSACTION ISOLATION LEVEL SNAPSHOT
| Dirty reads | Non-repeatable reads | Phantom reads | |
|---|---|---|---|
| READ UNCOMMITTED | ya | ya | ya |
| READ COMMITTED | tidak | ya | ya |
| REPEATABLE READ | tidak | tidak | ya |
| SERIALIZABLE | tidak | tidak | tidak |
| SNAPSHOT | tidak | tidak | tidak |
Transaksi1
SET TRANSACTION ISOLATION LEVEL SNAPSHOT
BEGIN TRAN
SELECT * FROM accounts;
|account_id|account_number |...| current_balance|
|----------|--------------------|---|----------------|
|1 |55555555551234567890|...| 25000,00 |
|2 |55555555559876543210|...| 200,00 |
|... |... |...| ... |
|15 |55555555551234567890|...| 25000,00 |
Transaksi2
...
...
BEGIN TRAN
INSERT INTO accounts
VALUES (11111111111111111111, 1, 25000);
UPDATE accounts
SET current_balance = 30000 WHERE account_id = 1;
SELECT * FROM accounts;
COMMIT TRAN
Tidak terblokir!
Transaksi1
SET TRANSACTION ISOLATION LEVEL SNAPSHOT
BEGIN TRAN
SELECT * FROM accounts;
SELECT * FROM accounts;
|account_id|account_number |...| current_balance|
|----------|--------------------|---|----------------|
|1 |55555555551234567890|...| 25000,00 |
|2 |55555555559876543210|...| 200,00 |
|... |... |...| ... |
|15 |55555555551234567890|...| 25000,00 |
Transaksi2
...
...
BEGIN TRAN
INSERT INTO accounts
VALUES (11111111111111111111, 1, 25000);
UPDATE accounts
SET current_balance = 30000 WHERE account_id = 1;
SELECT * FROM accounts;
COMMIT TRAN
Tidak terblokir!
Kelebihan:
Kekurangan:
tempDB bertambahKapan digunakan?:
ALTER DATABASE myDatabaseName SET READ_COMMITTED_SNAPSHOT {ON|OFF};
Default OFF
Untuk mengaktifkan ON:
ALTER DATABASE myDatabaseName SET ALLOW_SNAPSHOT_ISOLATION ON;
Transaksi1
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRAN
UPDATE accounts
SET current_balance = 30000
WHERE account_id = 1;

COMMIT TRAN
Transaksi2
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRAN

SELECT current_balance FROM accounts
WHERE account_id = 1;
| current_balance |
|-----------------|
| 35000,00 |
Transaksi1
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRAN
UPDATE accounts
SET current_balance = 30000
WHERE account_id = 1;

COMMIT TRAN
Transaksi2
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRAN

SELECT current_balance FROM accounts
WHERE account_id = 1;
SELECT current_balance FROM accounts
WHERE account_id = 1;
| current_balance |
|-----------------|
| 30000,00 |
READ UNCOMMITTED berlaku untuk seluruh koneksi / WITH (NOLOCK) berlaku untuk tabel tertentuSaldo awal akun 5 = $35.000
Transaksi1
BEGIN TRAN
UPDATE accounts
SET current_balance = 30000
WHERE account_id = 5;
Transaksi2
...
...
...
SELECT current_balance
FROM accounts WITH (NOLOCK)
WHERE account_id = 5;
| current_balance |
|-----------------|
| 30000,00 |
Transaksi dan Penanganan Kesalahan di SQL Server