Transazioni e gestione degli errori in SQL Server
Miriam Antona
Software Engineer
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
| Dirty reads | Non-repeatable reads | Phantom reads | |
|---|---|---|---|
| READ UNCOMMITTED | yes | yes | yes |
| READ COMMITTED | no | yes | yes |
| REPEATABLE READ | no | no | yes |
| SERIALIZABLE | no | no | no |
WHERE basata su un intervallo di indice -> Blocca solo quei recordTransazione 1
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN
SELECT * FROM customers
WHERE customer_id BETWEEN 1 AND 3;
| customer_id | first_name | last_name | ... | phone |
|-------------|------------|-----------|-----|-----------|
| 1 | Dylan | Smith | ... | 555888999 |
Record bloccato
Transazione 1
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN
SELECT * FROM customers
WHERE customer_id BETWEEN 1 AND 3;
| customer_id | first_name | last_name | ... | phone |
|-------------|------------|-----------|-----|-----------|
| 1 | Dylan | Smith | ... | 555888999 |
Record bloccato
Transazione 2
...
...
INSERT INTO customers (customer_id, first_name, ...)
VALUES (2, 'Phantom', 'Ph', '[email protected]', 555666222);
Deve aspettare!
Transazione 1
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN
SELECT * FROM customers
WHERE customer_id BETWEEN 1 AND 3;

SELECT * FROM customers
WHERE customer_id BETWEEN 1 AND 3;
| customer_id | first_name | last_name | ... | phone |
|-------------|------------|-----------|-----|-----------|
| 1 | Dylan | Smith | ... | 555888999 |
Transazione 2
...
...
INSERT INTO customers (customer_id, first_name, ...)
VALUES (2, 'Phantom', 'Ph', '[email protected]', 555666222);
Deve aspettare!
Transazione 1
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN
SELECT * FROM customers
WHERE customer_id BETWEEN 1 AND 3;

SELECT * FROM customers
WHERE customer_id BETWEEN 1 AND 3;
COMMIT TRAN
Transazione 2
...
...
INSERT INTO customers (customer_id, first_name, ...)
VALUES (2, 'Phantom', 'Ph', '[email protected]', 555666222);
Eseguito alla fine!
Transazione 1
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN
SELECT * FROM customers
WHERE customer_id BETWEEN 1 AND 3;
| customer_id | first_name | last_name | ... | phone |
|-------------|------------|-----------|-----|-----------|
| 1 | Dylan | Smith | ... | 555888999 |
Transazione 2
...
...
INSERT INTO customers (customer_id, first_name, ...)
VALUES (200, 'Phantom', 'Ph', '[email protected]', 555666222);
Inserito subito!
Transazione 1
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN
SELECT * FROM customers;
| customer_id | first_name | last_name | ... | phone |
|-------------|------------|-----------| ... |-----------|
| 1 | Dylan | Smith | ... | 555888999 |
...
| 10 | Carol | York | ... | 555148988 |
Blocca l'intera tabella
Transazione 2
...
...
INSERT INTO customers
VALUES (100, 'Phantom', 'Ph', '[email protected]', 555666222);
Deve aspettare!
Transazione 1
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN
SELECT * FROM customers;

SELECT * FROM customers;
| customer_id | first_name | last_name | ... | phone |
|-------------|------------|-----------| ... |-----------|
| 1 | Dylan | Smith | ... | 555888999 |
...
| 10 | Carol | York | ... | 555148988 |
Transazione 2
...
...
INSERT INTO customers
VALUES (100, 'Phantom', 'Ph', '[email protected]', 555666222);
Deve aspettare!
Transazione 1
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
BEGIN TRAN
SELECT * FROM customers;

SELECT * FROM customers;
COMMIT TRAN
Transazione 2
...
...
INSERT INTO customers
VALUES (100, 'Phantom', 'Ph', '[email protected]', 555666222);
Eseguito alla fine!
Pro:
Contro:
SERIALIZABLEQuando usarlo?:
Transazioni e gestione degli errori in SQL Server