Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 24/02/2011, 18h33   #1
Invité de passage
 
Inscription : février 2011
Messages : 7
Détails du profil
Informations forums :
Inscription : février 2011
Messages : 7
Points : 3
Points : 3
Par défaut probleme de trigger

bonjour,


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

ma table:
Code :
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 :
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.
Franz_O est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/02/2011, 23h24   #2
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 544
Points : 9 544
Pour moi, ça marche en ajoutant le BEGIN qui te manque :

Code :
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 :
1
2
3
INSERT INTO ligand_nom VALUES (1, 'toto', 1) ;
INSERT INTO ligand_nom VALUES (1, 'tata', 1) ;
SELECT * FROM ligand_nom ;
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/02/2011, 14h05   #3
Invité de passage
 
Inscription : février 2011
Messages : 7
Détails du profil
Informations forums :
Inscription : février 2011
Messages : 7
Points : 3
Points : 3
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 :
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.
Franz_O est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/02/2011, 14h43   #4
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 544
Points : 9 544
euh, a priori c'est un bug de ta version de MySQL
http://dev.mysql.com/doc/refman/5.0/...l-upgrade.html
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/02/2011, 16h26   #5
Invité de passage
 
Inscription : février 2011
Messages : 7
Détails du profil
Informations forums :
Inscription : février 2011
Messages : 7
Points : 3
Points : 3
ca marche nickel maintenant


merci beaucoup.
Franz_O est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 16h45.


 
 
 
 
Partenaires

Hébergement Web