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] opération avant/apres un bloc IF


Sujet :

SQL Procédural MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Homme Profil pro
    Développeur
    Inscrit en
    Août 2003
    Messages
    1 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Août 2003
    Messages : 1 497
    Par défaut [trigger] opération avant/apres un bloc IF
    Bonjour,
    Je cherche a executer plusieurs commande dans un trigger dont le code se trouve ci-dessous :
    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
    DELIMITER $$
    DROP TRIGGER `db`.`MAJ_dossier`$$
    create trigger `db`.`MAJ_dossier` AFTER UPDATE on `db`.`dossiers` 
    for each row BEGIN
    	IF OLD.recu IS NULL AND NEW.recu IS NOT NULL AND DATEDIFF(NOW(), NEW.depot)<=5 THEN
    		INSERT INTO mail VALUES(NEW.id_dossier, '1');
    	ELSEIF OLD.recu IS NULL AND NEW.recu IS NOT NULL AND DATEDIFF(NOW(), NEW.depot) BETWEEN 6 AND 29 THEN
    		INSERT INTO mail VALUES(NEW.id_dossier, '2');
    	ELSEIF OLD.recu IS NULL AND NEW.recu IS NOT NULL AND DATEDIFF(NOW(), NEW.depot) BETWEEN 30 AND 50 THEN
    		INSERT INTO mail VALUES(NEW.id_dossier, '3');
    	ELSEIF OLD.recu IS NULL AND NEW.recu IS NOT NULL AND DATEDIFF(NOW(), NEW.depot)>50 THEN
    		INSERT INTO mail VALUES(NEW.id_dossier, '4');
    	END IF;
    	/*UPDATE dossiers SET last_maj=NOW() WHERE id_dossier=NEW.id_dossier;*/
    END;
    $$
    DELIMITER ;
    Si je ne décommente pas l'UPDATE, je peux effectuer seulement des insertions/suppression mais il m'est impossible d'effectuer des UPDATE.

  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
    Si dans ton trigger AFTER UPDATE tu fais un UPDATE sur la même table, tu fais une boucle infinie de triggers.

    Il suffit que tu fasses
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SET new.last_maj = NOW() ;
    et de préférence dans un trigger BEFORE UPDATE.

    Sinon, tu peux aussi utiliser ON UPDATE CURRENT TIMESTAMP.

  3. #3
    Membre éprouvé
    Homme Profil pro
    Développeur
    Inscrit en
    Août 2003
    Messages
    1 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Août 2003
    Messages : 1 497
    Par défaut
    Comment fonctionne le :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ON UPDATE CURRENT TIMESTAMP
    Je dois le mettre dans le trigger ?
    Lorsque je défini l'attribut ?

  4. #4
    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
    dans la définition de la colonne (les entités ont des attributs, mais les tables ont des colonnes). RTFM http://dev.mysql.com/doc/refman/5.0/en/timestamp.html.

  5. #5
    Membre éprouvé
    Homme Profil pro
    Développeur
    Inscrit en
    Août 2003
    Messages
    1 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Août 2003
    Messages : 1 497
    Par défaut
    Ca ne marche pas, j'ai essayé ca avec CURRENT_TIMSTAMP (erreur : Invalid default value for 'last_maj') et CURRENT_DATE (erreur de syntaxe) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    ALTER TABLE `dossier`
    	CHANGE `last_maj` `last_maj`
    	DATE NOT NULL
    	DEFAULT CURRENT_TIMESTAMP
    	ON UPDATE CURRENT_TIMESTAMP
    	COMMENT 'Date de dernière modification d''un enregistrement.'
    ;
    PS : mon attribut last_maj est de type DATE et j'aimerai bien le conserver si possible.

  6. #6
    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
    Citation Envoyé par smarties
    PS : mon attribut last_maj est de type DATE et j'aimerai bien le conserver si possible.
    Le ON UPDATE CURRENT TIMESTAMP ne marche qu'avec un type TIMESTAMP.

  7. #7
    Membre éprouvé
    Homme Profil pro
    Développeur
    Inscrit en
    Août 2003
    Messages
    1 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Août 2003
    Messages : 1 497
    Par défaut
    Ca a l'air de marcher, merci pour ton aide.

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

Discussions similaires

  1. Les styles des éléments avant/après compilation
    Par Mysti¢ dans le forum wxPython
    Réponses: 2
    Dernier message: 14/06/2007, 17h07
  2. TRIGGER (test avant ajout) ne fonctionne pas correctement
    Par marcusien dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/06/2007, 18h02
  3. [Base de Registres]Comparer Avant-Aprés
    Par Jean_Benoit dans le forum Autres Logiciels
    Réponses: 4
    Dernier message: 21/06/2006, 20h14
  4. [CSS] Espace avant / après un <ul>
    Par Torpedox dans le forum Mise en page CSS
    Réponses: 7
    Dernier message: 10/01/2006, 21h34
  5. Boutons IE vs Firefox: espaces avant/après le texte
    Par dasdeb dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 07/09/2005, 19h29

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