PL / SQL - Pemicu

Pada bab ini, kita akan membahas Pemicu di PL / SQL. Pemicu adalah program yang disimpan, yang dijalankan atau dijalankan secara otomatis ketika beberapa peristiwa terjadi. Faktanya, pemicu ditulis untuk dieksekusi sebagai respons terhadap salah satu peristiwa berikut -

  • SEBUAH database manipulation (DML) pernyataan (DELETE, INSERT, atau UPDATE)

  • SEBUAH database definition (DDL) pernyataan (CREATE, ALTER, atau DROP).

  • SEBUAH database operation (SERVERERROR, LOGON, LOGOFF, STARTUP, atau SHUTDOWN).

Pemicu dapat ditentukan di tabel, tampilan, skema, atau database yang terkait dengan peristiwa tersebut.

Manfaat Pemicu

Pemicu dapat ditulis untuk tujuan berikut -

  • Menghasilkan beberapa nilai kolom turunan secara otomatis
  • Menerapkan integritas referensial
  • Event logging dan menyimpan informasi pada akses tabel
  • Auditing
  • Replikasi tabel secara sinkron
  • Menerapkan otorisasi keamanan
  • Mencegah transaksi tidak valid

Membuat Pemicu

Sintaks untuk membuat pemicu adalah -

CREATE [OR REPLACE ] TRIGGER trigger_name  
{BEFORE | AFTER | INSTEAD OF }  
{INSERT [OR] | UPDATE [OR] | DELETE}  
[OF col_name]  
ON table_name  
[REFERENCING OLD AS o NEW AS n]  
[FOR EACH ROW]  
WHEN (condition)   
DECLARE 
   Declaration-statements 
BEGIN  
   Executable-statements 
EXCEPTION 
   Exception-handling-statements 
END;

Dimana,

  • BUAT [ATAU GANTI] TRIGGER trigger_name - Membuat atau mengganti trigger yang ada dengan trigger_name .

  • {SEBELUM | SETELAH | INSTEAD OF} - Ini menentukan kapan pemicu akan dieksekusi. Klausa INSTEAD OF digunakan untuk membuat pemicu pada tampilan.

  • {SISIPKAN [OR] | UPDATE [ATAU] | HAPUS} - Ini menentukan operasi DML.

  • [OF col_name] - Ini menentukan nama kolom yang akan diperbarui.

  • [ON table_name] - Ini menentukan nama tabel yang terkait dengan pemicu.

  • [MEREFERENSI LAMA SEBAGAI BARU AS n] - Ini memungkinkan Anda untuk merujuk nilai baru dan lama untuk berbagai pernyataan DML, seperti INSERT, UPDATE, dan DELETE.

  • [UNTUK SETIAP BARIS] - Ini menentukan pemicu tingkat baris, yaitu, pemicu akan dijalankan untuk setiap baris yang terpengaruh. Jika tidak, pemicu akan dijalankan hanya sekali saat pernyataan SQL dijalankan, yang disebut pemicu tingkat tabel.

  • WHEN (kondisi) - Ini memberikan kondisi untuk baris yang akan memicu pemicu. Klausul ini hanya berlaku untuk pemicu tingkat baris.

Contoh

Untuk memulainya, kita akan menggunakan tabel CUSTOMERS yang telah kita buat dan gunakan di bab sebelumnya -

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+

Program berikut membuat file row-levelpemicu untuk tabel pelanggan yang akan mengaktifkan operasi INSERT atau UPDATE atau DELETE yang dilakukan pada tabel CUSTOMERS. Pemicu ini akan menampilkan perbedaan gaji antara nilai lama dan nilai baru -

CREATE OR REPLACE TRIGGER display_salary_changes 
BEFORE DELETE OR INSERT OR UPDATE ON customers 
FOR EACH ROW 
WHEN (NEW.ID > 0) 
DECLARE 
   sal_diff number; 
BEGIN 
   sal_diff := :NEW.salary  - :OLD.salary; 
   dbms_output.put_line('Old salary: ' || :OLD.salary); 
   dbms_output.put_line('New salary: ' || :NEW.salary); 
   dbms_output.put_line('Salary difference: ' || sal_diff); 
END; 
/

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

Trigger created.

Poin-poin berikut perlu dipertimbangkan di sini -

  • Referensi LAMA dan BARU tidak tersedia untuk pemicu tingkat tabel, Anda dapat menggunakannya untuk pemicu tingkat catatan.

  • Jika Anda ingin membuat kueri tabel di pemicu yang sama, Anda harus menggunakan kata kunci SETELAH, karena pemicu dapat membuat kueri tabel atau mengubahnya lagi hanya setelah perubahan awal diterapkan dan tabel kembali dalam keadaan konsisten.

  • Pemicu di atas telah ditulis sedemikian rupa sehingga akan diaktifkan sebelum operasi DELETE atau INSERT atau UPDATE apa pun pada tabel, tetapi Anda dapat menulis pemicu Anda pada satu atau beberapa operasi, misalnya SEBELUM DIHAPUS, yang akan diaktifkan setiap kali ada record akan dihapus menggunakan operasi DELETE pada tabel.

Memicu Pemicu

Mari kita lakukan beberapa operasi DML pada tabel CUSTOMERS. Berikut adalah satu pernyataan INSERT, yang akan membuat record baru di tabel -

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (7, 'Kriti', 22, 'HP', 7500.00 );

Saat record dibuat di tabel CUSTOMERS, pemicu di atas membuat, display_salary_changes akan dipecat dan itu akan menampilkan hasil sebagai berikut -

Old salary: 
New salary: 7500 
Salary difference:

Karena ini adalah rekor baru, gaji lama tidak tersedia dan hasil di atas dianggap nol. Sekarang mari kita melakukan satu operasi DML lagi di tabel PELANGGAN. Pernyataan UPDATE akan memperbarui catatan yang ada di tabel -

UPDATE customers 
SET salary = salary + 500 
WHERE id = 2;

Ketika record diperbarui dalam tabel CUSTOMERS, pemicu di atas membuat, display_salary_changes akan dipecat dan itu akan menampilkan hasil sebagai berikut -

Old salary: 1500 
New salary: 2000 
Salary difference: 500