Problème avec la clé secondaire

Résolu/Fermé
laurette97 Messages postés 5 Date d'inscription lundi 23 octobre 2017 Statut Membre Dernière intervention 25 octobre 2017 - 23 oct. 2017 à 13:21
laurette97 Messages postés 5 Date d'inscription lundi 23 octobre 2017 Statut Membre Dernière intervention 25 octobre 2017 - 25 oct. 2017 à 12:21
coucou communauté CCM je suis en train de créer une base de donnée avec sql de msql workbench.
en faite j' ai d' abord créer la table fournisseur et en suite la table livraison qui reçoit la clé primaire de t-fournisseur comme clé secondaire comme vous pouvez le constater ci-dessous mais le soucis est que msql me ramène #1075 - Un seul champ automatique est permis et il doit être indexé a l' exécution.
Et quand j’enlève l'auto-incrément a la idfournisseur se trouvant dans la t-livraison il me ramène #1005 - Ne peut créer la table `essaie`.`livraison` (Errcode: 150 "Foreign key constraint is incorrectly formed")



CREATE TABLE fournisseur
(
idfournisseur INT(5) NOT null AUTO_INCREMENT,
nomfournisseur varchar(45) not null,
prenomfournisseur varchar(45) not null,
telephonefournisseur INT(8) NOT null,
CONSTRAINT pk PRIMARY KEY(idfournisseur)
)
ENGINE = INNODB;


CREATE TABLE livraison
(
idlivraison INT NOT null AUTO_INCREMENT,
idfournisseur INT(5) NOT null AUTO_INCREMENT,
datelivraison datetime not null,
CONSTRAINT pk PRIMARY KEY(idlivraison),
CONSTRAINT pk PRIMARY KEY(idfournisseur),
CONSTRAINT fk FOREIGN KEY(idfournisseur) REFERENCES fournisseur(id)
)
ENGINE = INNODB;
A voir également:

2 réponses

yg_be Messages postés 22724 Date d'inscription lundi 9 juin 2008 Statut Contributeur Dernière intervention 25 avril 2024 1 476
24 oct. 2017 à 10:12
bonjour, je pense qu'il n'est pas permis d'avoir deux clés primaires (PRIMARY) pour la même table.
je suggère de supprimer la ligne
CONSTRAINT pk PRIMARY KEY(idfournisseur),
pour la table livraison.
0
laurette97 Messages postés 5 Date d'inscription lundi 23 octobre 2017 Statut Membre Dernière intervention 25 octobre 2017
24 oct. 2017 à 16:44
heho meme quand je supprime la ligne indique ça me rapporte toujoours une erreur
0
yg_be Messages postés 22724 Date d'inscription lundi 9 juin 2008 Statut Contributeur Dernière intervention 25 avril 2024 1 476
Modifié le 24 oct. 2017 à 16:50
il faudrait aussi supprimer AUTO_INCREMENT dans la définition de idfournisseur de la table livraison
et corriger ceci
CONSTRAINT fk FOREIGN KEY(idfournisseur) REFERENCES fournisseur(id) 

en cela
CONSTRAINT fk FOREIGN KEY(idfournisseur) REFERENCES fournisseur(idfournisseur) 
0
laurette97 Messages postés 5 Date d'inscription lundi 23 octobre 2017 Statut Membre Dernière intervention 25 octobre 2017 > yg_be Messages postés 22724 Date d'inscription lundi 9 juin 2008 Statut Contributeur Dernière intervention 25 avril 2024
25 oct. 2017 à 12:21
merci infiniment j'ai suivi tes conseils et ce la a résolu mon problème
0