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 :

problem trigger supprimer


Sujet :

SQL Procédural MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de moukit233
    Développeur informatique
    Inscrit en
    Mai 2009
    Messages
    240
    Détails du profil
    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mai 2009
    Messages : 240
    Par défaut problem trigger supprimer
    Salut,
    j'ai un trigger qui se chargera de supprimer les clefs etranger de l'élément supprimé.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    DROP TRIGGER IF EXISTS `suppression`//
    CREATE TRIGGER `suppression` BEFORE DELETE ON TABLE1
     FOR EACH ROW BEGIN
        delete from TABLE2  where ID=OLD.id and type=OLD.type;
        delete from TABLE3  where ID=OLD.id and type=OLD.type;
        delete from TABLE4 where ID=OLD.id and type=OLD.type;  
    END//
    mais j'ai un erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    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 '//
    CREATE TRIGGER `suppression` BEFORE DELETE ON table1
    FOR' at line 1 
    je ne peux pas utiliser la suppression en cascade

    merci de votre aide

  2. #2
    Expert confirmé
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 932
    Par défaut
    Il faut commencer par et finir par Ceci dit, ton trigger s'appelle suppression, et l'erreur mentionne suppressionEavElement

  3. #3
    Membre éclairé Avatar de moukit233
    Développeur informatique
    Inscrit en
    Mai 2009
    Messages
    240
    Détails du profil
    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mai 2009
    Messages : 240
    Par défaut
    merci de votre reponse,
    en fait j'ai testé avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    DROP TRIGGER IF EXISTS `suppression`
    delimiter //
    CREATE TRIGGER `suppression` BEFORE DELETE ON TABLE1
     FOR EACH ROW BEGIN
        delete from TABLE2  where ID=OLD.id and type=OLD.type;
        delete from TABLE3  where ID=OLD.id and type=OLD.type;
        delete from TABLE4 where ID=OLD.id and type=OLD.type;  
    END//
    delimiter ;
    mais j'ai toujour un 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 'delimiter' at line 1 

  4. #4
    Expert confirmé
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 932
    Par défaut
    Pour le DROP, il faut qualifier le trigger avec le nom de la table
    Pour détruire un déclencheur, utilisez la commande DROP TRIGGER. Le nom du déclencheur doit inclure le nom de la table :
    http://dev.mysql.com/doc/refman/5.0/...-triggers.html

  5. #5
    Membre éclairé Avatar de moukit233
    Développeur informatique
    Inscrit en
    Mai 2009
    Messages
    240
    Détails du profil
    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mai 2009
    Messages : 240
    Par défaut
    Merci de votre reponse;
    il me semble que le problem n'existe ds la syntaxe de ma requette...
    le problem c'est ds l'onglet SQL de phpMyAdmin ds la zone text Délimiteur j'ai mis un ";" par contre je dois mettre "//"
    donc ma requette elle est bonne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    DROP TRIGGER IF EXISTS `suppression`//
    CREATE TRIGGER `suppression` BEFORE DELETE ON TABLE1
     FOR EACH ROW BEGIN
        delete from TABLE2  where ID=OLD.id and type=OLD.type;
        delete from TABLE3  where ID=OLD.id and type=OLD.type;
        delete from TABLE4 where ID=OLD.id and type=OLD.type;  
    END//

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 27/05/2006, 19h08
  2. probleme trigger
    Par sanyugioh dans le forum Oracle
    Réponses: 3
    Dernier message: 13/04/2006, 15h46
  3. Probleme trigger mysql 5
    Par DarkMax dans le forum SQL Procédural
    Réponses: 7
    Dernier message: 18/03/2006, 22h50
  4. Problem Trigger instead of
    Par bubi dans le forum Développement
    Réponses: 1
    Dernier message: 01/12/2005, 23h31
  5. probleme trigger
    Par samourai_alex dans le forum Oracle
    Réponses: 10
    Dernier message: 05/01/2005, 11h37

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