Transazioni e gestione degli errori in 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 | sì | sì | sì |
| READ COMMITTED | no | sì | sì |
| REPEATABLE READ | no | no | sì |
| SERIALIZABLE | no | no | no |
| SNAPSHOT | no | no | no |
Transazione1
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 |
Transazione2
...
...
BEGIN TRAN
INSERT INTO accounts
VALUES (11111111111111111111, 1, 25000);
UPDATE accounts
SET current_balance = 30000 WHERE account_id = 1;
SELECT * FROM accounts;
COMMIT TRAN
Non è bloccata!
Transazione1
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 |
Transazione2
...
...
BEGIN TRAN
INSERT INTO accounts
VALUES (11111111111111111111, 1, 25000);
UPDATE accounts
SET current_balance = 30000 WHERE account_id = 1;
SELECT * FROM accounts;
COMMIT TRAN
Non è bloccata!
Pro:
Contro:
tempDBQuando usarlo?
ALTER DATABASE myDatabaseName SET READ_COMMITTED_SNAPSHOT {ON|OFF};
OFF di default
Per usare ON:
ALTER DATABASE myDatabaseName SET ALLOW_SNAPSHOT_ISOLATION ON;
Transazione1
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRAN
UPDATE accounts
SET current_balance = 30000
WHERE account_id = 1;

COMMIT TRAN
Transazione2
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRAN

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

COMMIT TRAN
Transazione2
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 vale per l’intera connessione / WITH (NOLOCK) per una tabella specificaSaldo iniziale conto 5 = $35.000
Transazione1
BEGIN TRAN
UPDATE accounts
SET current_balance = 30000
WHERE account_id = 5;
Transazione2
...
...
...
SELECT current_balance
FROM accounts WITH (NOLOCK)
WHERE account_id = 5;
| current_balance |
|-----------------|
| 30000,00 |
Transazioni e gestione degli errori in SQL Server