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