Hatalarla ilgili bilgi verme

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

Miriam Antona

Software Engineer

Hata alma - tekrar

INSERT INTO products (product_name, stock, price)
    VALUES ('Trek Powerfly 5 - 2018', 10, 3499.99);
Msg 2627, Level 14, State 1, Line 1
UNIQUE KEY kısıtlaması 'unique_name' ihlali. 
'dbo.products' nesnesine yinelenen anahtar eklenemez. 
Yinelenen anahtar değeri: (Trek Powerfly 5 - 2018).
SQL Server'da İşlemler ve Hata Yönetimi

Hata alma - tekrar

BEGIN TRY
    INSERT INTO products (product_name, stock, price)
        VALUES ('Trek Powerfly 5 - 2018', 10, 3499.99);
    SELECT 'Product inserted correctly!' AS message;
END TRY
BEGIN CATCH
    SELECT 'An error occurred! You are in the CATCH block' AS message;  
END CATCH
| message                                       |
|-----------------------------------------------|
| An error occurred! You are in the CATCH block |
SQL Server'da İşlemler ve Hata Yönetimi

Hata işlevleri

ERROR_NUMBER() hata numarasını döndürür.

ERROR_SEVERITY() hata ciddiyetini döndürür (11-19).

ERROR_STATE() hata durumunu döndürür.

ERROR_LINE() hatanın satır numarasını döndürür.

ERROR_PROCEDURE() saklı yordam/tetikleyici adını döndürür. Saklı yordam/tetikleyici yoksa NULL.

ERROR_MESSAGE() hata iletisi metnini döndürür.

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

Hata işlevleri - örnekler

BEGIN TRY
    INSERT INTO products (product_name, stock, price)
        VALUES ('Trek Powerfly 5 - 2018', 10, 3499.99);
END TRY
BEGIN CATCH
    SELECT  ERROR_NUMBER() AS Error_number,  
            ERROR_SEVERITY() AS Error_severity,  
            ERROR_STATE() AS Error_state,  
            ERROR_PROCEDURE() AS Error_procedure,  
            ERROR_LINE() AS Error_line,  
            ERROR_MESSAGE() AS Error_message;             
END CATCH
| Error_number| Error_severity| Error_state| Error_procedure| Error_line| Error_message                                       |
|-------------|---------------|------------|----------------|-----------|-----------------------------------------------------|
| 2627        | 14            | 1          | NULL           | 2         | Violation of UNIQUE KEY constraint 'unique_name'... |
SQL Server'da İşlemler ve Hata Yönetimi

Hata işlevleri - örnekler

Son çıktı

| Error_number| Error_severity| Error_state| Error_procedure| Error_line| Error_message                                       |
|-------------|---------------|------------|----------------|-----------|-----------------------------------------------------|
| 2627        | 14            | 1          | NULL           | 2         | Violation of UNIQUE KEY constraint 'unique_name'... |

Özgün hata bilgisi

Msg 2627, Level 14, State 1, Line 1
Violation of UNIQUE KEY constraint 'unique_name'. Cannot insert duplicate key in object 'dbo.products'. The duplicate key 
value is (Trek Powerfly 5 - 2018).
SQL Server'da İşlemler ve Hata Yönetimi

Hata işlevleri - örnekler

SELECT  ERROR_NUMBER() AS Error_number,  
        ERROR_SEVERITY() AS Error_severity,  
        ERROR_STATE() AS Error_state,  
        ERROR_PROCEDURE() AS Error_procedure,  
        ERROR_LINE() AS Error_line,  
        ERROR_MESSAGE() AS Error_message;
| Error_number | Error_severity | Error_state | Error_procedure | Error_line | Error_message |
|--------------|----------------|-------------|-----------------|------------|---------------|
| NULL         | NULL           | NULL        | NULL            | NULL       | NULL          |
SQL Server'da İşlemler ve Hata Yönetimi

İç içe TRY...CATCH yapılarında hata işlevleri

BEGIN TRY
    INSERT INTO products (product_name, stock, price)
        VALUES ('Trek Powerfly 5 - 2018', 10, 3499.99);
END TRY
BEGIN CATCH
    BEGIN TRY
        INSERT INTO myErrors
            VALUES ('ERROR!')
    END TRY    
    BEGIN CATCH
        SELECT  'Outer CATCH block' AS 'Error_from',
            ERROR_NUMBER() AS Error_number,       
            ERROR_MESSAGE() AS Error_message; 
    END CATCH    
END CATCH
| Error_from        | Error_number | Error_message                             |
|-------------------|--------------|-------------------------------------------|
| Outer CATCH block | 8152         | String or binary data would be truncated. |
SQL Server'da İşlemler ve Hata Yönetimi

Hadi pratik yapalım!

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

Preparing Video For Download...