IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Oracle Discussion :

Désactiver le trigger en cours


Sujet :

Oracle

  1. #1
    Membre habitué
    Inscrit en
    Mai 2006
    Messages
    139
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Mai 2006
    Messages : 139
    Points : 147
    Points
    147
    Par défaut Désactiver le trigger en cours
    Bonjour,

    Je suis sous Oracle 9i.
    J'ai une table de personnes, une table temporaire correspondante et deux triggers.

    Le premier d'entre eux se déclenche sur modification d'un champ que l'on appellera unite1, et inscrit dans la table temporaire l'identifiant et la valeur du champ unite1.

    Pour résumer, le deuxième trigger va lire la table temporaire, et pour chaque entrée, s'il le faut, mettre a jour un champ unite2 avec la valeur d'unite1 pour une certaine population. J'aimerai également qu'il mette le champ unite1 de cette même population à NULL. Si je fais cela, le trigger plante en raison d'appels récursifs (puisque le champ unite1 est cette fois modifié, et déclenche à nouveau le trigger).

    J'ai essayé ALTER TRIGGER dans le trigger même pour le désactiver, mais survient alors l'erreur PLS-00103, ce qui me laisse penser qu'on ne peut pas appeler cette instruction dans un trigger même.

    Pouvez-vous m'éclairer sur le sujet ou me fournir une piste plus appropriée ?
    Merci d'avance.

  2. #2
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    pas d'autre choix que d'ajouter un flag qui permettra de ne pas déclenché le trigger une 2° fois. Le 1° trigger mettra le flag à N et ne se déclenche pas si le flag est à N... du coup plus de problème

    ceci étant, ça parait pas super ta solution

  3. #3
    Membre habitué
    Inscrit en
    Mai 2006
    Messages
    139
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Mai 2006
    Messages : 139
    Points : 147
    Points
    147
    Par défaut
    ceci étant, ça parait pas super ta solution
    Je vais exposer le problème dans sa globalité, ça me permettra de voir si quelqu'un a une meilleure idée :

    La table des personnes contient (notamment) les champs :
    • IDENTIFIANT
    • RESPONSABLE
    • UNITE
    • UNITE_RESPONSABLE


    Le fonctionnement souhaité est le suivant :
    • Si une personne n'a pas de responsable, l'unité que je reçois d'un script d'approvisionnement de la table est stockée dans le champ UNITE
    • Si une personne a un responsable, je dois récupérer l'unité de son responsable et la stocker dans UNITE_RESPONSABLE, tout en effaçant si nécessaire la valeur du champ UNITE


    Le recours à 2 triggers était nécessaire pour éviter l'erreur de table en mutation.

    Je suis à votre écoute si vous avez une solution plus efficace !
    Merci.

  4. #4
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    dans ce cas, vaut mieux utiliser le PRAGMA AUTONOMOUS_TRANSACTION pour récupérer la valeur du responsable

Discussions similaires

  1. désactiver un trigger
    Par JustMe dans le forum SQL
    Réponses: 4
    Dernier message: 20/06/2016, 08h59
  2. [SQL2K] Activation et Désactivation de trigger
    Par maitrebn dans le forum Développement
    Réponses: 7
    Dernier message: 04/05/2007, 17h11
  3. Autorisation de désactivation de trigger
    Par dev-man dans le forum Développement
    Réponses: 4
    Dernier message: 22/11/2006, 11h44
  4. [Syntaxe Oracle/Sybase] désactiver un trigger
    Par MashiMaro dans le forum Sybase
    Réponses: 3
    Dernier message: 30/10/2003, 11h17
  5. Désactiver un trigger sous MS Sql Server
    Par WOLO Laurent dans le forum Développement
    Réponses: 6
    Dernier message: 03/07/2003, 12h51

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo