Trigger before insert truncate

Fermé
NP3 Messages postés 1 Date d'inscription mardi 29 novembre 2022 Statut Membre Dernière intervention 29 novembre 2022 - 29 nov. 2022 à 19:42
jee pee Messages postés 40584 Date d'inscription mercredi 2 mai 2007 Statut Modérateur Dernière intervention 23 décembre 2024 - 30 nov. 2022 à 16:19

Bonjour,

je cherche un code pour trigger qui pourrait vider la table employer avant de la remplir avec de nouvelles données, merci

2 réponses

Panth33ra Messages postés 21073 Date d'inscription mercredi 8 juillet 2020 Statut Membre Dernière intervention 2 décembre 2024 Ambassadeur 1 875
30 nov. 2022 à 12:33

Bonjour,

J'ai trouvé ceci sur un autre forum mais est-ce bien cette méthode ?


0
jee pee Messages postés 40584 Date d'inscription mercredi 2 mai 2007 Statut Modérateur Dernière intervention 23 décembre 2024 9 460
30 nov. 2022 à 16:19

Bonjour,

Es-tu sur de vouloir faire un truncate sur la table (qui supprime tous les enregistrements) avant chaque insert ? C'est un type d'utilisation que l'on réserve généralement à une table de travail.

Si on regarde la doc on aura quelque chose comme :

CREATE OR REPLACE TRIGGER vider_employer
   BEFORE INSERT ON schema.employer
   BEGIN
      TRUNCATE TABLE employer;
   END;

Après TRUNCATE est un ordre SQL de type DDL comme CREATE TABLE, alors que SELECT, INSERT sont des ordres de type DML. La particularité d'un ordre DDL est qu'il est AUTO COMMIT, il valide toutes les opérations en attente de COMMIT. On ne pourra donc pas utiliser une table qui aurait un trigger database avec un TRUNCATE dans une transaction. Transaction au sens d'un ensemble d'ordre SQL cohérents, qui doivent, soit tous être exécutés, soit en cas d'anomalie aucun ne doit l'être.


0