Apache Derby - Déclencheurs

Dans les bases de données, les déclencheurs sont les instructions / code qui sont exécutés chaque fois qu'un événement se produit. Une fois que vous avez créé un déclencheur pour un événement particulier sur une table, le code spécifié dans le déclencheur est exécuté à chaque fois que l'événement se produit. Vous pouvez créer plusieurs déclencheurs sur une seule table.

Ce chapitre vous apprend à créer et supprimer des déclencheurs à l'aide d'Apache Derby.

Créer un déclencheur

Vous pouvez créer un déclencheur dans Derby à l'aide de l'instruction CREATE TRIGGER.

Syntaxe

Voici la syntaxe de la requête CREATE TRIGGER.

CREATE TRIGGER trigger_name
{ NO CASCADE BEFORE | AFTER }
{INSERT [OR] | UPDATE [OR] | DELETE}[OF col_name]
ON table_name
[REFERENCING OLD AS o NEW AS n]
[FOR EACH ROW]
Statement

Exemple

Supposons que nous ayons créé une table nommée Emp dans Derby comme indiqué ci-dessous.

CREATE TABLE Emp (
   Id INT NOT NULL,
   Name VARCHAR(255),
   Salary INT NOT NULL,
   Location VARCHAR(255) );

Et inséré 5 lignes dedans.

INSERT INTO Emp(Id, Name, Salary, Location) VALUES
(1, 'Amit', 30000, 'Hyderabad'), (2, 'Kalyan', 40000, 'Vishakhapatnam'),
(3,'Renuka', 50000, 'Delhi'), (4, 'Archana', 15000, 'Mumbai'), (5, 'Trupthi',
45000, 'Kochin');

Si nous avons une autre table nommée BackUp et que notre intention est de stocker les lignes supprimées de la table Emp dans ce fichier.

CREATE TABLE BackUp (
   Id INT NOT NULL,
   Name VARCHAR(255),
   Salary INT NOT NULL,
   Location VARCHAR(255)
);

La requête suivante crée un déclencheur sur la table de requête DELETE nommée Emp. Il stocke les lignes supprimées deEmp à la table Sauvegarde.

ij> CREATE TRIGGER my_trigger
AFTER DELETE ON Emp
REFERENCING OLD AS oldRow
FOR EACH ROW MODE DB2SQL
INSERT INTO BackUp
VALUES (oldRow.Id, oldRow.Name, oldRow.Salary, oldRow.Location);

Maintenant, supprimez une ligne de la table Emp comme -

ij> Delete From Emp where Name = 'Kalyan';
1 row inserted/updated/deleted
ij> Delete From Emp where Name = 'Amit';
1 row inserted/updated/deleted

Si vous vérifiez la table BackUp, vous pouvez y observer les lignes supprimées.

ij> select * from BackUp;
ID |NAME |SALARY |LOCATION
-------------------------------------------------------------------------
2 |Kalyan |40000 |Vishakhapatnam
1 |Amit |30000 |Hyderabad

2 rows selected

Supprimer un déclencheur

Vous pouvez supprimer un déclencheur dans Derby à l'aide de l'instruction DROP TRIGGER.

Syntaxe

Voici la syntaxe de la requête DROP TRIGGER -

ij> Drop trigger tigger_name;

Exemple

L'exemple suivant supprime le déclencheur my_trigger créé ci-dessus -

ij> Drop trigger my_trigger;
0 rows inserted/updated/deleted

Exemple JDBC

Le programme JDBC suivant crée et supprime les déclencheurs dans Derby.

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class Triggers_Example {
   public static void main(String args[]) throws SQLException, ClassNotFoundException {
      //Registering the driver
      Class.forName("org.apache.derby.jdbc.EmbeddedDriver");
      //Getting the Connection object
      String URL = "jdbc:derby:TestDataBase;create=true";
      Connection conn = DriverManager.getConnection(URL);

      //Creating the Statement object
      Statement stmt = conn.createStatement();

      //Creating the Emp table
      stmt.execute("CREATE TABLE Emp ( "
         + "Id INT NOT NULL, "
         + "Name VARCHAR(255), "
         + "Salary INT NOT NULL, "
         + "Location VARCHAR(255))");

      //Insert values in to the EMp table
      String query = "INSERT INTO Emp(Id, Name, Salary, Location) VALUES \r\n"
         +"(1, 'Amit', 30000, 'Hyderabad'), "
         + "(2, 'Kalyan', 40000, 'Vishakhapatnam'), "
         + "(3,'Renuka', 50000, 'Delhi'), "
         + "(4, 'Archana', 15000, 'Mumbai'), "
         + "(5, 'Trupthi', 45000, 'Kochin')";
         stmt.execute(query);

      //Creating the BackUp table
      stmt.execute("CREATE TABLE BackUp ( "
         + "Id INT NOT NULL, "
         + "Name VARCHAR(255), "
         + "Salary INT NOT NULL, "
         + "Location VARCHAR(255))");

      //Creating a trigger
      String createTrigger = "CREATE TRIGGER my_trigger "
         + "AFTER DELETE ON Emp "
         + "REFERENCING OLD AS oldRow "
         + "FOR EACH ROW MODE DB2SQL "
         + "INSERT INTO BackUp "
         + "VALUES (oldRow.Id, oldRow.Name, oldRow.Salary, oldRow.Location)";
      stmt.execute(createTrigger);
      System.out.println("Trigger created");

      //Deleting records from Emp table
      stmt.executeUpdate("Delete From Emp where Name = 'Kalyan'");
      stmt.executeUpdate("Delete From Emp where Name = 'Amit'");
      //Getting the contents of BackUp table
      ResultSet rs = stmt.executeQuery("SELECT * from BackUp");
      while(rs.next()){
         System.out.println(rs.getInt("Id"));
         System.out.println(rs.getString("Name"));
         System.out.println(rs.getString("Salary"));
         System.out.println(rs.getString("Location"));
         System.out.println(" ");
      }
   }
}

Production

Lors de l'exécution du programme ci-dessus, la sortie suivante est générée -

Trigger created
2
Kalyan
40000
Vishakhapatnam
1
Amit
30000
Hyderabad