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, variables et IF [MySQL-5.1]


Sujet :

SQL Procédural MySQL

  1. #1
    Nouveau membre du Club
    Inscrit en
    Juin 2010
    Messages
    44
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 44
    Points : 38
    Points
    38
    Par défaut TRIGGER, variables et IF
    Bonjour,

    Je souhaite mettre en place le TRIGGER ci-après.
    Le but, ON UPDATE de la table mac_ligne_fam, compter le nombre de lignes non validées (valide = 0) et si nul exécuter une requête sur la table mac_ligne_cde.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    CREATE TRIGGER update_ligne_fam
    AFTER UPDATE ON mac_ligne_fam
    FOR EACH ROW
    BEGIN
        DECLARE nbLig INTEGER;
     
        -- Compte le nombre de familles non validées pour cette ligne de commande
        SELECT COUNT( * ) INTO nbLig
        FROM mac_ligne_fam
        WHERE id_cde = NEW.id_cde
            AND id_lig = NEW.id_lig
            AND valide = 0;
     
        -- Si 0 alors met à jour la ligne de commande
        IF nbLig = 0 THEN
            UPDATE mac_ligne_cde
            SET valide=1
            WHERE id_cde = NEW.id_cde
            AND id_lig = NEW.id_lig;
        END IF;
    END;
    Je suis sur un serveur mutualisé 1&1, et lorsque je lance cette requête depuis phpMyAdmin, j'ai cette erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    #1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 5
    La ligne 5 est celle du DECLARE ...

    Si quelqu'un arrive à dénicher la faute de syntaxe ou de structure, je lui en serais reconnaissant.

    D'avance merci.

  2. #2
    Nouveau membre du Club
    Inscrit en
    Juin 2010
    Messages
    44
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 44
    Points : 38
    Points
    38
    Par défaut
    Bonjour ...

    Le problème ne venait pas de ma requête mais de la déclaration des délimiteurs ... Comme chez 1&1 on ne peut déclarer un changement de délimiteurs, j'ai dû installer Adminer pour exécuter ma requête de création du TRIGGER ...

    Désolé pour le dérangement ...

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

Discussions similaires

  1. variable trigger
    Par papy_tergnier dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 02/03/2006, 10h21
  2. Réponses: 9
    Dernier message: 31/01/2006, 10h04
  3. Variable OUTPUT dans Trigger
    Par Yanmeunier dans le forum Développement
    Réponses: 4
    Dernier message: 09/12/2005, 14h38
  4. Procédures stockées, Trigger et variables internes
    Par lio33 dans le forum InterBase
    Réponses: 1
    Dernier message: 01/09/2005, 11h28
  5. Réponses: 5
    Dernier message: 25/11/2003, 10h41

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