Problème avec la clé secondaire

Résolu
laurette97 Messages postés 5 Date d'inscription   Statut Membre Dernière intervention   -  
laurette97 Messages postés 5 Date d'inscription   Statut Membre Dernière intervention   -
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 23541 Date d'inscription   Statut Contributeur Dernière intervention   Ambassadeur 1 584
 
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   Statut Membre Dernière intervention  
 
heho meme quand je supprime la ligne indique ça me rapporte toujoours une erreur
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584
 
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   Statut Membre Dernière intervention   > yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention  
 
merci infiniment j'ai suivi tes conseils et ce la a résolu mon problème
0