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 :

la syntaxe de mon trigger est fausse !


Sujet :

SQL Procédural MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Août 2007
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 47
    Par défaut la syntaxe de mon trigger est fausse !
    Bonjour tout le monde,

    voila mon trigger :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    create trigger trig_max 
    after update on matrix5 for each row
    begin
    update network_node inner join
     (SELECT num_node,max(risk_node)as max 
    FROM matrix5 
    group by num_node)
     b2 on b2.num_node = network_node.num_node 
    set network_node.max_risk_node = b2.max
    end ;
    sachant que la requête entre begin et end fonctionne bien lorsque je l'exécute séparément.

    lorsque j'essaie avec mon trigger sous mysql server5.0 il me génère une erreur de syntaxe 1064 .

    Merci d'avance.

  2. #2
    Membre averti
    Inscrit en
    Août 2007
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 47
    Par défaut
    Bonjour,
    et bon voilà j'ai trouvé la solution , j'ai juste enlevé le begin et le end et HOP ça fonctionne très bien !!!
    je répète que j'utilise mysql 5.0.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     
    CREATE TRIGGER trig_max 
    after UPDATE ON matrix5 FOR each row
     
    UPDATE network_node INNER JOIN
     (SELECT num_node,max(risk_node)AS max 
    FROM matrix5 
    GROUP BY num_node)
     b2 ON b2.num_node = network_node.num_node 
    SET network_node.max_risk_node = b2.max ;
    Toujours je n'oublie pas de dire merci à developpez.com
    Bon travail à tous.

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

Discussions similaires

  1. [Pattern][Regex] vérifier que mon email est valide
    Par anitshka dans le forum Collection et Stream
    Réponses: 7
    Dernier message: 23/05/2011, 13h03
  2. mauvaise syntaxe de mon déclencheur (trigger)
    Par elvan49 dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 30/11/2007, 09h56
  3. mon poste est invisible depuis le serveur
    Par StyleXP dans le forum Administration
    Réponses: 13
    Dernier message: 08/01/2006, 22h32
  4. [Sécurité] Savoir si mon visiteur est un humain
    Par toure32 dans le forum Langage
    Réponses: 8
    Dernier message: 08/01/2006, 15h13
  5. [Access] Mon application est détruite !!!
    Par mathias dans le forum Access
    Réponses: 4
    Dernier message: 26/06/2003, 14h14

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