XACT_ABORT ve XACT_STATE

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

Miriam Antona

Software Engineer

XACT_ABORT

Hata oluştuğunda geçerli işlemin otomatik geri alınıp alınmayacağını belirtir.

SET XACT_ABORT { ON | OFF }
SET XACT_ABORT OFF
  • Varsayılan ayar
  • Hata olursa: Açık işlemler kalabilir
SET XACT_ABORT ON
  • Hata olursa: İşlemi geri alır ve yürütmeyi durdurur
SQL Server'da İşlemler ve Hata Yönetimi

XACT_ABORT - örnekler

SET XACT_ABORT OFF; --Default setting

BEGIN TRAN;
    INSERT INTO customers VALUES ('Mark', 'Davis', '[email protected]', '555909090');
    INSERT INTO customers VALUES ('Dylan', 'Smith', '[email protected]', '555888999'); -- ERROR!
COMMIT TRAN;
(1 row affected)
Msg. 2627, Level 14, State 1, Line 5
Violation of UNIQUE KEY 'unique_email'...
| customer_id | first_name | last_name | email                | phone     |
|-------------|------------|-----------|----------------------|-----------|
| 14          | Mark       | Davis     | [email protected]   | 555909090 |
SQL Server'da İşlemler ve Hata Yönetimi

XACT_ABORT - örnekler

SET XACT_ABORT ON;

BEGIN TRAN;
    INSERT INTO customers VALUES ('Mark', 'Davis', '[email protected]', '555909090');
    INSERT INTO customers VALUES ('Dylan', 'Smith', '[email protected]', '555888999'); -- ERROR!
COMMIT TRAN;
Msg. 2627, Level 14, State 1, Line 4
Violation of UNIQUE KEY 'unique_email'...
SELECT * FROM customers WHERE first_name = 'Mark';
| customer_id | first_name | last_name | email                | phone     |
|-------------|------------|-----------|----------------------|-----------|
SQL Server'da İşlemler ve Hata Yönetimi

RAISERROR ile XACT_ABORT

SET XACT_ABORT ON;
BEGIN TRAN;
    INSERT INTO customers VALUES ('Mark', 'Davis', '[email protected]', '555909090');
    RAISERROR('Raising an error!', 16, 1);
    INSERT INTO customers VALUES ('Zack', 'Roberts', '[email protected]', '555919191');
COMMIT TRAN;
Msg. 50000, Level 16, State 1, Line 5
Raising an error!
SELECT * FROM customers WHERE first_name IN ('Mark', 'Zack');
| customer_id | first_name | last_name | email                | phone     |
|-------------|------------|-----------|----------------------|-----------|
| 14          | Mark       | Davis     | [email protected]   | 555909090 |
| 15          | Zack       | Roberts   | [email protected] | 555919191 |
SQL Server'da İşlemler ve Hata Yönetimi

THROW ile XACT_ABORT

SET XACT_ABORT ON;
BEGIN TRAN;
    INSERT INTO customers VALUES ('Mark', 'Davis', '[email protected]', '555909090');
    THROW 55000, 'Raising an error!', 1;
    INSERT INTO customers VALUES ('Zack', 'Roberts', '[email protected]', '555919191');
COMMIT TRAN;
(1 rows affected)
Msg. 50000, Level 16, State 1, Line 5
Raising an error!
SELECT * FROM customers WHERE first_name IN ('Mark', 'Zack');
| customer_id | first_name | last_name | email | phone |
|-------------|------------|-----------|-------|-------|
SQL Server'da İşlemler ve Hata Yönetimi

XACT_STATE

XACT_STATE()
  • 0 -> açık işlem yok
  • 1 -> açık ve taahhüt edilebilir işlem
  • -1 -> açık ama taahhüt edilemez işlem (bozulmuş)
    • taahhüt edilemez
    • bir kayıt noktasına geri alınamaz
    • tüm işlem geri alınabilir
    • değişiklik yapılamaz/okuma yapılabilir
SQL Server'da İşlemler ve Hata Yönetimi

XACT_STATE - açık ve taahhüt edilebilir

SET XACT_ABORT OFF;
BEGIN TRY
    BEGIN TRAN;
        INSERT INTO customers VALUES ('Mark', 'Davis', '[email protected]', '555909090');
        INSERT INTO customers VALUES ('Dylan', 'Smith', '[email protected]', '555888999'); -- ERROR!
    COMMIT TRAN;
END TRY
BEGIN CATCH
    IF XACT_STATE() = -1
        ROLLBACK TRAN;
    IF XACT_STATE() = 1
        COMMIT TRAN;
    SELECT ERROR_MESSAGE() AS error_message;
END CATCH
| error_message                               |
|---------------------------------------------|
| Violation of UNIQUE KEY 'unique_email'...   |
SQL Server'da İşlemler ve Hata Yönetimi

XACT_STATE - açık ve taahhüt edilebilir

| customer_id | first_name | last_name | email                | phone     |
|-------------|------------|-----------|----------------------|-----------|
| 14          | Mark       | Davis     | [email protected]   | 555909090 |
SQL Server'da İşlemler ve Hata Yönetimi

XACT_STATE - açık ama taahhüt edilemez (bozulmuş)

SET XACT_ABORT ON;
BEGIN TRY
    BEGIN TRAN;
        INSERT INTO customers VALUES ('Mark', 'Davis', '[email protected]', '555909090');
        INSERT INTO customers VALUES ('Dylan', 'Smith', '[email protected]', '555888999'); -- ERROR!
    COMMIT TRAN;
END TRY
BEGIN CATCH
    IF XACT_STATE() = -1
        ROLLBACK TRAN;
    IF XACT_STATE() = 1
        COMMIT TRAN;
    SELECT ERROR_MESSAGE() AS Error_message;
END CATCH
SQL Server'da İşlemler ve Hata Yönetimi

XACT_STATE - açık ama taahhüt edilemez (bozulmuş)

SELECT * FROM customers WHERE first_name = 'Mark';
| customer_id | first_name | last_name | email                | phone     |
|-------------|------------|-----------|----------------------|-----------|
SQL Server'da İşlemler ve Hata Yönetimi

Hadi pratik yapalım!

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

Preparing Video For Download...