PL / SQL - İstisnalar

Bu bölümde, PL / SQL'deki İstisnaları tartışacağız. İstisna, bir programın yürütülmesi sırasındaki bir hata durumudur. PL / SQL, programcıların bu tür koşulları yakalamasını destekler.EXCEPTIONprogramdaki blok ve hata durumuna karşı uygun bir işlem yapılır. İki tür istisna vardır -

  • Sistem tanımlı istisnalar
  • Kullanıcı tanımlı istisnalar

Özel Durum İşleme için Sözdizimi

İstisna işleme için genel sözdizimi aşağıdaki gibidir. Burada işleyebileceğiniz kadar çok istisnayı listeleyebilirsiniz. Varsayılan istisna kullanılarak ele alınacaktırWHEN others THEN -

DECLARE 
   <declarations section> 
BEGIN 
   <executable command(s)> 
EXCEPTION 
   <exception handling goes here > 
   WHEN exception1 THEN  
      exception1-handling-statements  
   WHEN exception2  THEN  
      exception2-handling-statements  
   WHEN exception3 THEN  
      exception3-handling-statements 
   ........ 
   WHEN others THEN 
      exception3-handling-statements 
END;

Misal

Kavramı açıklamak için bir kod yazalım. Önceki bölümlerde oluşturduğumuz ve kullandığımız MÜŞTERİLER tablosunu kullanacağız -

DECLARE 
   c_id customers.id%type := 8; 
   c_name customerS.Name%type; 
   c_addr customers.address%type; 
BEGIN 
   SELECT  name, address INTO  c_name, c_addr 
   FROM customers 
   WHERE id = c_id;  
   DBMS_OUTPUT.PUT_LINE ('Name: '||  c_name); 
   DBMS_OUTPUT.PUT_LINE ('Address: ' || c_addr); 

EXCEPTION 
   WHEN no_data_found THEN 
      dbms_output.put_line('No such customer!'); 
   WHEN others THEN 
      dbms_output.put_line('Error!'); 
END; 
/

Yukarıdaki kod SQL isteminde çalıştırıldığında, aşağıdaki sonucu verir -

No such customer!  

PL/SQL procedure successfully completed.

Yukarıdaki program, kimliği verilen bir müşterinin adını ve adresini gösterir. Veritabanımızda ID değeri 8 olan bir müşteri olmadığı için, program çalışma zamanı istisnasını yükseltirNO_DATA_FOUND, içinde yakalanan EXCEPTION block.

İstisnaları Artırma

Herhangi bir dahili veritabanı hatası olduğunda, veritabanı sunucusu tarafından istisnalar otomatik olarak ortaya çıkar, ancak istisnalar, komut kullanılarak programcı tarafından açıkça ortaya çıkarılabilir. RAISE. Aşağıda, bir istisna oluşturmak için basit sözdizimi verilmiştir -

DECLARE 
   exception_name EXCEPTION; 
BEGIN 
   IF condition THEN 
      RAISE exception_name; 
   END IF; 
EXCEPTION 
   WHEN exception_name THEN 
   statement; 
END;

Oracle standart istisnasını veya herhangi bir kullanıcı tanımlı istisnayı yükseltmek için yukarıdaki sözdizimini kullanabilirsiniz. Bir sonraki bölümde, size kullanıcı tanımlı bir istisna oluşturmaya ilişkin bir örnek vereceğiz. Oracle standart istisnalarını da benzer şekilde artırabilirsiniz.

Kullanıcı Tanımlı İstisnalar

PL / SQL, programınızın ihtiyacına göre kendi istisnalarınızı tanımlamanıza izin verir. Kullanıcı tanımlı bir istisna beyan edilmeli ve ardından bir RAISE ifadesi veya prosedür kullanılarak açıkça belirtilmelidir.DBMS_STANDARD.RAISE_APPLICATION_ERROR.

Bir istisna bildirmek için sözdizimi -

DECLARE 
   my-exception EXCEPTION;

Misal

Aşağıdaki örnek kavramı göstermektedir. Bu program, kullanıcı geçersiz bir kimlik girdiğinde bir müşteri kimliği ister, istisnainvalid_id yükseltilir.

DECLARE 
   c_id customers.id%type := &cc_id; 
   c_name customerS.Name%type; 
   c_addr customers.address%type;  
   -- user defined exception 
   ex_invalid_id  EXCEPTION; 
BEGIN 
   IF c_id <= 0 THEN 
      RAISE ex_invalid_id; 
   ELSE 
      SELECT  name, address INTO  c_name, c_addr 
      FROM customers 
      WHERE id = c_id;
      DBMS_OUTPUT.PUT_LINE ('Name: '||  c_name);  
      DBMS_OUTPUT.PUT_LINE ('Address: ' || c_addr); 
   END IF; 

EXCEPTION 
   WHEN ex_invalid_id THEN 
      dbms_output.put_line('ID must be greater than zero!'); 
   WHEN no_data_found THEN 
      dbms_output.put_line('No such customer!'); 
   WHEN others THEN 
      dbms_output.put_line('Error!');  
END; 
/

Yukarıdaki kod SQL isteminde çalıştırıldığında, aşağıdaki sonucu verir -

Enter value for cc_id: -6 (let's enter a value -6) 
old  2: c_id customers.id%type := &cc_id; 
new  2: c_id customers.id%type := -6; 
ID must be greater than zero! 
 
PL/SQL procedure successfully completed.

Önceden Tanımlanmış İstisnalar

PL / SQL, herhangi bir veritabanı kuralı bir program tarafından ihlal edildiğinde yürütülen birçok önceden tanımlanmış istisna sağlar. Örneğin, bir SELECT INTO deyimi satır döndürmediğinde önceden tanımlanmış NO_DATA_FOUND istisnası ortaya çıkar. Aşağıdaki tablo, önceden tanımlanmış önemli istisnalardan birkaçını listelemektedir -

İstisna Oracle Hatası SQLCODE Açıklama
ACCESS_INTO_NULL 06530 -6530 Boş bir nesneye otomatik olarak bir değer atandığında yükseltilir.
CASE_NOT_FOUND 06592 -6592 Bir CASE ifadesinin WHEN yan tümcesindeki seçimlerden hiçbiri seçilmediğinde ve ELSE yan tümcesi olmadığında ortaya çıkar.
COLLECTION_IS_NULL 06531 -6531 Bir program, başlatılmamış iç içe geçmiş tabloya veya değişkene EXISTS dışındaki toplama yöntemlerini uygulamaya çalıştığında veya program, başlatılmamış iç içe geçmiş bir tablo veya varray öğelerine değerler atamaya çalıştığında ortaya çıkar.
DUP_VAL_ON_INDEX 00001 -1 Yinelenen değerler, benzersiz indeksi olan bir sütunda depolanmaya çalışıldığında ortaya çıkar.
INVALID_CURSOR 01001 -1001 Açılmamış bir imleci kapatmak gibi izin verilmeyen bir imleç işlemi yapma girişiminde bulunulduğunda yükseltilir.
GEÇERSİZ NUMARA 01722 -1722 Bir karakter dizesinin bir sayıya dönüştürülmesi başarısız olduğunda, dize geçerli bir sayıyı temsil etmediğinden ortaya çıkar.
LOGIN_DENIED 01017 -1017 Bir program veritabanında geçersiz bir kullanıcı adı veya parola ile oturum açmaya çalıştığında ortaya çıkar.
VERİ BULUNAMADI 01403 +100 Bir SELECT INTO ifadesi satır döndürmediğinde yükseltilir.
NOT_LOGGED_ON 01012 -1012 Veritabanına bağlanılmadan bir veritabanı çağrısı yayınlandığında ortaya çıkar.
PROGRAM_ERROR 06501 -6501 PL / SQL'de dahili bir sorun olduğunda ortaya çıkar.
ROWTYPE_MISMATCH 06504 -6504 Bir imleç, uyumsuz veri türüne sahip bir değişkendeki değeri getirdiğinde yükseltilir.
SELF_IS_NULL 30625 -30625 Bir üye yöntemi çağrıldığında, ancak nesne türünün örneği başlatılmadığında ortaya çıkar.
STORAGE_ERROR 06500 -6500 PL / SQL belleği bittiğinde veya bellek bozulduğunda yükseltilir.
TOO_MANY_ROWS 01422 -1422 Bir SELECT INTO ifadesi birden fazla satır döndürdüğünde ortaya çıkar.
VALUE_ERROR 06502 -6502 Bir aritmetik, dönüştürme, kesme veya boyut kısıtlama hatası oluştuğunda ortaya çıkar.
ZERO_DIVIDE 01476 1476 Bir sayıyı sıfıra bölme girişiminde bulunulduğunda yükseltilir.