PL / SQL - Pengecualian

Dalam bab ini, kita akan membahas Pengecualian di PL / SQL. Pengecualian adalah kondisi kesalahan selama eksekusi program. PL / SQL mendukung pemrogram untuk menangkap kondisi seperti itu menggunakanEXCEPTIONblokir dalam program dan tindakan yang tepat diambil terhadap kondisi kesalahan. Ada dua jenis pengecualian -

  • Pengecualian yang ditentukan sistem
  • Pengecualian yang ditentukan pengguna

Sintaks untuk Penanganan Pengecualian

Sintaks umum untuk penanganan pengecualian adalah sebagai berikut. Di sini Anda dapat membuat daftar pengecualian sebanyak yang Anda bisa tangani. Pengecualian default akan ditangani menggunakanWHEN 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;

Contoh

Mari kita tulis kode untuk menggambarkan konsep tersebut. Kami akan menggunakan tabel CUSTOMERS yang telah kami buat dan gunakan di bab sebelumnya -

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; 
/

Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

No such customer!  

PL/SQL procedure successfully completed.

Program di atas menampilkan nama dan alamat pelanggan yang ID-nya diberikan. Karena tidak ada pelanggan dengan nilai ID 8 di database kami, program memunculkan pengecualian waktu prosesNO_DATA_FOUND, yang ditangkap di EXCEPTION block.

Meningkatkan Pengecualian

Pengecualian dimunculkan oleh server basis data secara otomatis setiap kali ada kesalahan basis data internal, tetapi pengecualian dapat dimunculkan secara eksplisit oleh pemrogram dengan menggunakan perintah RAISE. Berikut ini adalah sintaks sederhana untuk memunculkan pengecualian -

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

Anda dapat menggunakan sintaks di atas untuk meningkatkan pengecualian standar Oracle atau pengecualian yang ditentukan pengguna. Di bagian selanjutnya, kami akan memberi Anda contoh tentang memunculkan pengecualian yang ditentukan pengguna. Anda dapat meningkatkan pengecualian standar Oracle dengan cara yang serupa.

Pengecualian Buatan Pengguna

PL / SQL memungkinkan Anda untuk menentukan pengecualian Anda sendiri sesuai dengan kebutuhan program Anda. Pengecualian yang ditentukan pengguna harus dideklarasikan dan kemudian dimunculkan secara eksplisit, baik menggunakan pernyataan RAISE atau prosedurDBMS_STANDARD.RAISE_APPLICATION_ERROR.

Sintaks untuk mendeklarasikan pengecualian adalah -

DECLARE 
   my-exception EXCEPTION;

Contoh

Contoh berikut menggambarkan konsep tersebut. Program ini meminta ID pelanggan, ketika pengguna memasukkan ID yang tidak valid, pengecualianinvalid_id dibesarkan.

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; 
/

Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

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.

Pengecualian yang Ditentukan Sebelumnya

PL / SQL menyediakan banyak pengecualian yang telah ditentukan sebelumnya, yang dijalankan ketika ada aturan database yang dilanggar oleh program. Misalnya, pengecualian NO_DATA_FOUND yang telah ditentukan dimunculkan ketika pernyataan SELECT INTO tidak mengembalikan baris. Tabel berikut mencantumkan beberapa pengecualian penting yang telah ditentukan sebelumnya -

Pengecualian Kesalahan Oracle SQLCODE Deskripsi
ACCESS_INTO_NULL 06530 -6530 Dibesarkan ketika objek null secara otomatis diberi nilai.
CASE_NOT_FOUND 06592 -6592 Dibesarkan jika tidak ada pilihan dalam klausa WHEN dari pernyataan CASE yang dipilih, dan tidak ada klausa ELSE.
COLLECTION_IS_NULL 06531 -6531 Dibesarkan saat program mencoba menerapkan metode pengumpulan selain EXISTS ke tabel atau varray bersarang yang tidak diinisialisasi, atau program mencoba menetapkan nilai ke elemen tabel atau varray bersarang yang tidak diinisialisasi.
DUP_VAL_ON_INDEX 00001 -1 Dibesarkan saat nilai duplikat berusaha disimpan dalam kolom dengan indeks unik.
INVALID_CURSOR 01001 -1001 Dibesarkan ketika upaya dilakukan untuk membuat operasi kursor yang tidak diperbolehkan, seperti menutup kursor yang belum dibuka.
INVALID_NUMBER 01722 -1722 Dibesarkan ketika konversi string karakter menjadi angka gagal karena string tidak mewakili angka yang valid.
LOGIN_DENIED 01017 -1017 Dibesarkan ketika sebuah program mencoba untuk masuk ke database dengan nama pengguna atau kata sandi yang tidak valid.
TIDAK ADA DATA DITEMUKAN 01403 +100 Dibesarkan ketika pernyataan SELECT INTO tidak mengembalikan baris.
NOT_LOGGED_ON 01012 -1012 Dibesarkan ketika panggilan database dikeluarkan tanpa terhubung ke database.
PROGRAM_ERROR 06501 -6501 Dibesarkan ketika PL / SQL memiliki masalah internal.
ROWTYPE_MISMATCH 06504 -6504 Dibesarkan saat kursor mengambil nilai dalam variabel yang memiliki tipe data yang tidak kompatibel.
SELF_IS_NULL 30625 -30625 Ini dimunculkan ketika metode anggota dipanggil, tetapi instance dari tipe objek tidak diinisialisasi.
STORAGE_ERROR 06500 -6500 Dibesarkan ketika PL / SQL kehabisan memori atau memori rusak.
TOO_MANY_ROWS 01422 -1422 Dibesarkan ketika pernyataan SELECT INTO mengembalikan lebih dari satu baris.
VALUE_ERROR 06502 -6502 Dibesarkan ketika terjadi kesalahan aritmatika, konversi, pemotongan, atau batasan ukuran.
ZERO_DIVIDE 01476 1476 Dibesarkan saat percobaan dilakukan untuk membagi angka dengan nol.