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 :

probleme de trigger


Sujet :

SQL Procédural MySQL

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Février 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 7
    Par défaut probleme de trigger
    bonjour,


    J'ai actuellement un petit problème par rapport à un trigger.

    ma table:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    CREATE TABLE IF NOT EXISTS `ligand_nom` (
      `id_lig` int(11) NOT NULL,
      `nom` varchar(250) NOT NULL,
      `officiel` BOOL NOT NULL,
      PRIMARY KEY (`id_lig`, `nom`),
      FOREIGN KEY (`id_lig`) REFERENCES ligands(`id`)
    ) ENGINE=InnoDB;
    un ligand pouvant avoir de multiples (n) synonymes, mais un seul nom officiel, le booléen sera donc pour un même id_lig : (n-1) fois à 0 et 1 fois à 1.

    J'ai donc crée un trigger, pour éviter l'ajout de plus d'un nom considéré comme officiel :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    DELIMITER //
    CREATE TRIGGER `trig_add_nom_lig`
    BEFORE INSERT ON `ligand_nom` 
    FOR EACH ROW
      IF (NEW.officiel>=1) THEN 
        DECLARE COMPTEUR_OFF INTEGER; 
        SELECT count(id_lig) INTO COMPTEUR_OFF FROM ligand_nom WHERE id_lig=NEW.id_lig AND officiel=NEW.officiel; 
        IF (COMPTEUR_OFF>=1) THEN
          SET NEW.officiel=0; 
        END IF; 
      END IF; 
    END;//
    DELIMITER ;
    malheureusement, ça ne fonctionne pas, je peux toujours insérer des données avec le même id_lig et officiel à 1...

    Si quelqu'un a une petite idée du pourquoi du comment ... ça m'aiderai beaucoup

    Merci d'avance.

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    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 284
    Par défaut
    Pour moi, ça marche en ajoutant le BEGIN qui te manque :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    DELIMITER //
    CREATE TRIGGER `trig_add_nom_lig`
    BEFORE INSERT ON `ligand_nom` 
    FOR EACH ROW
    BEGIN
    DECLARE COMPTEUR_OFF INTEGER; 
    	IF (NEW.officiel>=1) THEN SELECT count(id_lig) INTO COMPTEUR_OFF FROM ligand_nom WHERE id_lig=NEW.id_lig AND officiel=NEW.officiel; 
        IF (COMPTEUR_OFF>=1) THEN
          SET NEW.officiel=0; 
        END IF; 
      END IF; 
    END;//
    DELIMITER ;
    Test :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    insert into ligand_nom values (1, 'toto', 1) ;
    insert into ligand_nom values (1, 'tata', 1) ;
    select * from ligand_nom ;

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Février 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 7
    Par défaut
    Merci, c'est sûr qu'avec tous les mots ça fonctionne mieux...

    Cependant je rencontre un second problème dès que j'essaye d'insérer quelque chose dans la table sous le trigger, j'obtiens ce message d'érreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    mysql> insert into ligand_nom values ("1","plop","1");
     
    ERROR 1558 (HY000): Column count of mysql.proc is wrong. Expected 20, found 16. Created with MySQL 50077, now running 50155. Please use mysql_upgrade to fix this error.

  4. #4
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    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 284
    Par défaut
    euh, a priori c'est un bug de ta version de MySQL
    http://dev.mysql.com/doc/refman/5.0/...l-upgrade.html

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Février 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 7
    Par défaut
    ca marche nickel maintenant


    merci beaucoup.

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

Discussions similaires

  1. probleme de trigger
    Par [ME]yeye dans le forum Oracle
    Réponses: 6
    Dernier message: 15/06/2006, 15h33
  2. Problème comportement trigger
    Par ameno_123 dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 04/05/2006, 00h20
  3. Probleme de trigger
    Par Lomme dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 09/03/2006, 10h39
  4. Probleme de trigger
    Par luciemacherie dans le forum Oracle
    Réponses: 4
    Dernier message: 16/01/2006, 17h21
  5. [JDBC]Probleme avec trigger Oracle
    Par aurel89 dans le forum JDBC
    Réponses: 2
    Dernier message: 02/08/2005, 11h53

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