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

PL/SQL Oracle Discussion :

Trigger et transaction [10g]


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif

    Homme Profil pro
    Responsable projets techniques
    Inscrit en
    Février 2003
    Messages
    980
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable projets techniques
    Secteur : Biens de consommation

    Informations forums :
    Inscription : Février 2003
    Messages : 980
    Par défaut Trigger et transaction
    Hello,

    j'ai un trigger AFTER UPDATE sur une table. Est-ce qu'il est possible de demander à ce trigger d'attendre la fin de la transaction (le commit) avant de se déclencher ?

    Mon problème est que le trigger déclenche via un ordonnanceur un traitement en fonction de la valeur d'un champ.

    Pour faire des tests, je fais parfois un UPDATE manuel du champ. Si j'oublie d'enchainer directement le COMMIT, le traitement déclenché se plante parce que le champ n'est pas encore mis à jour en base (il l'est uniquement dans ma transaction)...

    Bref, rien de bien grave vu qu'on PROD, les COMMIT sont toujours faits juste après l'UPDATE, mais pour ma culture personnelle, est-ce possible ? (je n'ai rien trouvé pour le moment )

    Merci d'avance.

    Alexis

  2. #2
    Membre expérimenté
    Inscrit en
    Janvier 2010
    Messages
    135
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 135
    Par défaut
    How to fire trigger on commit statement? (Doc ID 1991749.1)

    "Oracle provides no direct means to modify the commit processing.

    Applications needs to be modified to directly modify the tables.

    There is an enhancment request Bug 3392454 - PROVIDE A TRIGGER THAT FIRES BEFORE COMMITS"

  3. #3
    Membre très actif

    Homme Profil pro
    Responsable projets techniques
    Inscrit en
    Février 2003
    Messages
    980
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable projets techniques
    Secteur : Biens de consommation

    Informations forums :
    Inscription : Février 2003
    Messages : 980
    Par défaut
    C'est ce que je craignais !

    Étonnant qu'on ne puisse pas déclencher le trigger après que la mise à jour soit vraiment faite en base... est-ce que ça veut dire que si un trigger se déclenche mais que finalement la transaction échoue, le rollback concerne également toute opération qui aurait été opérée par le trigger en base ?

  4. #4
    Membre expérimenté
    Inscrit en
    Janvier 2010
    Messages
    135
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 135
    Par défaut
    Citation Envoyé par lennelei Voir le message
    si un trigger se déclenche mais que finalement la transaction échoue, le rollback concerne également toute opération qui aurait été opérée par le trigger en base ?
    Oui, à l'exception d'une autonomous transaction à l'intérieur du trigger.

  5. #5
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Citation Envoyé par lennelei Voir le message
    ...
    Mon problème est que le trigger déclenche via un ordonnanceur un traitement en fonction de la valeur d'un champ.
    ...
    Il y a deux ordonnanceurs fournis par Oracle: DBMS_JOB et DBMS_SCHEDULER qui diffèrent parmi autres dans leur comportement transactionnel: DBMS_JOB ne se déclenche que après la validation de la transaction (commit) ce qui n'est pas le cas pour DBMS_SCHEDULER.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [2008R2] Trigger et transactions
    Par Donpi dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 03/10/2014, 10h06
  2. Syntaxe Trigger Mysql / Transact SQL de SQL Server
    Par Flashball dans le forum SQL Procédural
    Réponses: 8
    Dernier message: 13/03/2008, 15h23
  3. [PL/SQL] Creation de triggers dans transaction
    Par globeriding dans le forum Oracle
    Réponses: 15
    Dernier message: 07/02/2006, 11h33
  4. petite aide sur les transactions et triggers SVP
    Par CharleLéo dans le forum Débuter
    Réponses: 4
    Dernier message: 15/11/2004, 20h43

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