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

SQL Procédural MySQL Discussion :

Trigger et update


Sujet :

SQL Procédural MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13
    Par défaut Trigger et update
    Bonjour à tous.

    Je travaille actuellement sur les triggers MySQL pour un projet et je suis confronté à un problème depuis aujourd'hui.

    Je possède une table 'abc'. Mon trigger 'trig_abc' est branché dessus. En voici le code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    DELIMITER //
    CREATE TRIGGER trig_abc
    BEFORE INSERT ON abc
    FOR EACH ROW
    BEGIN
                 UPDATE abc SET champ2 = '999' WHERE champ1 = NEW.champ1;
    END//
    DELMITER ;
    En gros, je souhaite modifier la valeur de tous les 'champ2' de 'abc' lorsque 'champ1' vaut la valeur du 'champ' de la nouvelle ligne, avant insertion.

    Seulement MySQL n'est pas content et c'est même normal : j'essaie de mettre à jour une table déjà en lecture. L'exception levé par mon programme Java le confirme :
    "java.sql.SQLException: Can't update table 'abc' in stored function/trigger because it is already used by statement which invoked this stored function/trigger."
    Connaîtriez-vous une solution pour remédier à ce problème ?
    Je vous remercie d'avance.

    moheissenger

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 287
    Par défaut
    réponse en trois temps :

    1) ce n'est pas normal de devoir faire ça, ça sent l'erreur de modélisation

    2) en utilisant un AFTER INSERT au lieu du BEFORE, tu devrais éviter le problème

    3) au passage, comme ton trigger ne contient qu'une seule requête, le BEGIN... END n'est pas nécessaire, ce qui t'évite le bins avec les DELIMITER

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13
    Par défaut
    Bonjour.
    1) En effet, il y avait un léger problème de modélisation.
    2) Ca n'a pas marcher pour moi. Bien que le UPDATE se ferait après l'INSERT, le message comme quoi je suis toujours en lecture sur la table 'abc' subsiste.
    3) En effet, je gagne en lisibilité et en nombre de lignes de code, également dans d'autres triggers.

    J'ai réussi à faire ce que je voulais en modifiant le modèle et en branchant le trigger sur une nouvelle table qui a une jointure avec 'abc' et qui me permet d'effectuer alors mon UPDATE.

    Merci pour tes conseils avisés.
    @ bientot

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

Discussions similaires

  1. Trigger et update
    Par Solovely dans le forum Oracle
    Réponses: 2
    Dernier message: 03/05/2006, 17h36
  2. Trigger if update
    Par b_lob dans le forum MS SQL Server
    Réponses: 10
    Dernier message: 20/04/2006, 14h49
  3. [8i][forms 6i] trigger PRE-UPDATE
    Par Magnus dans le forum Oracle
    Réponses: 6
    Dernier message: 21/02/2006, 11h57
  4. TRIGGER After Update
    Par Nounoursonne dans le forum Oracle
    Réponses: 8
    Dernier message: 20/07/2005, 13h33
  5. Réponses: 2
    Dernier message: 29/09/2004, 09h07

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