PL / SQL - Déclencheurs

Dans ce chapitre, nous aborderons les déclencheurs en PL / SQL. Les déclencheurs sont des programmes stockés, qui sont automatiquement exécutés ou déclenchés lorsque certains événements se produisent. Les déclencheurs sont, en fait, écrits pour être exécutés en réponse à l'un des événements suivants -

  • UNE database manipulation (DML) instruction (DELETE, INSERT ou UPDATE)

  • UNE database definition (DDL) instruction (CREATE, ALTER ou DROP).

  • UNE database operation (SERVERERROR, LOGON, LOGOFF, STARTUP ou SHUTDOWN).

Les déclencheurs peuvent être définis sur la table, la vue, le schéma ou la base de données à laquelle l'événement est associé.

Avantages des déclencheurs

Les déclencheurs peuvent être écrits aux fins suivantes -

  • Générer automatiquement des valeurs de colonne dérivées
  • Faire respecter l'intégrité référentielle
  • Journalisation des événements et stockage des informations sur l'accès aux tables
  • Auditing
  • Réplication synchrone des tables
  • Imposer des autorisations de sécurité
  • Empêcher les transactions invalides

Créer des déclencheurs

La syntaxe pour créer un déclencheur est -

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;

Où,

  • CREATE [OR REPLACE] TRIGGER trigger_name - Crée ou remplace un trigger existant par trigger_name .

  • {AVANT | APRÈS | INSTEAD OF} - Ceci spécifie quand le déclencheur sera exécuté. La clause INSTEAD OF est utilisée pour créer un déclencheur sur une vue.

  • {INSÉRER [OU] | MISE À JOUR [OU] | DELETE} - Ceci spécifie l'opération DML.

  • [OF col_name] - Ceci spécifie le nom de la colonne qui sera mis à jour.

  • [ON nom_table] - Ceci spécifie le nom de la table associée au déclencheur.

  • [REFERENCING OLD AS o NEW AS n] - Cela vous permet de faire référence aux valeurs nouvelles et anciennes pour diverses instructions DML, telles que INSERT, UPDATE et DELETE.

  • [FOR EACH ROW] - Ceci spécifie un déclencheur au niveau de la ligne, c'est-à-dire que le déclencheur sera exécuté pour chaque ligne affectée. Sinon, le déclencheur ne s'exécutera qu'une seule fois lorsque l'instruction SQL est exécutée, ce qui est appelé un déclencheur de niveau table.

  • WHEN (condition) - Ceci fournit une condition pour les lignes pour lesquelles le déclencheur serait déclenché. Cette clause n'est valide que pour les déclencheurs de niveau ligne.

Exemple

Pour commencer, nous utiliserons la table CUSTOMERS que nous avons créée et utilisée dans les chapitres précédents -

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 | 
+----+----------+-----+-----------+----------+

Le programme suivant crée un row-leveldéclencheur pour la table clients qui se déclencherait pour les opérations INSERT ou UPDATE ou DELETE effectuées sur la table CUSTOMERS. Ce déclencheur affichera la différence de salaire entre les anciennes valeurs et les nouvelles valeurs -

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

Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -

Trigger created.

Les points suivants doivent être considérés ici -

  • Les références ANCIENNES et NOUVELLES ne sont pas disponibles pour les déclencheurs de niveau table, vous pouvez plutôt les utiliser pour les déclencheurs de niveau enregistrement.

  • Si vous souhaitez interroger la table dans le même déclencheur, vous devez utiliser le mot clé AFTER, car les déclencheurs peuvent interroger la table ou la modifier à nouveau uniquement après que les modifications initiales ont été appliquées et que la table est revenue dans un état cohérent.

  • Le déclencheur ci-dessus a été écrit de telle manière qu'il se déclenchera avant toute opération DELETE, INSERT ou UPDATE sur la table, mais vous pouvez écrire votre déclencheur sur une ou plusieurs opérations, par exemple BEFORE DELETE, qui se déclenchera chaque fois qu'un enregistrement sera supprimé à l'aide de l'opération DELETE sur la table.

Déclencher un déclencheur

Faisons quelques opérations DML sur la table CUSTOMERS. Voici une instruction INSERT, qui créera un nouvel enregistrement dans la table -

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

Lorsqu'un enregistrement est créé dans la table CUSTOMERS, le déclencheur de création ci-dessus, display_salary_changes sera déclenché et affichera le résultat suivant -

Old salary: 
New salary: 7500 
Salary difference:

Comme il s'agit d'un nouvel enregistrement, l'ancien salaire n'est pas disponible et le résultat ci-dessus est nul. Exécutons maintenant une autre opération DML sur la table CUSTOMERS. L'instruction UPDATE mettra à jour un enregistrement existant dans la table -

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

Lorsqu'un enregistrement est mis à jour dans la table CUSTOMERS, le déclencheur de création ci-dessus, display_salary_changes sera déclenché et affichera le résultat suivant -

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