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

Outils MySQL Discussion :

Erreur création table avec cle etrangere


Sujet :

Outils MySQL

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    245
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2002
    Messages : 245
    Points : 320
    Points
    320
    Par défaut Erreur création table avec cle etrangere
    Bonjour,

    J'essaye désespérément de créer une table avec des clés étrangères mais ca ne fonctionne pas. C'est la seule table qui ne fonctionne pas, les autres tables avec clés étrangères ont été créées sans aucun problème.

    Cette table est OK:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    CREATE TABLE t_QteOptVeh (
      `FK_Vehicule` INT NOT NULL, CONSTRAINT `FK_Vehicule_OV` FOREIGN KEY(`FK_Vehicule`) REFERENCES `T_Vehicule`(`IdVehicule`),
      `FK_Option` INT  NOT NULL, CONSTRAINT `FK_Option_OV` FOREIGN KEY(`FK_Option`) REFERENCES `T_Options`(`IdOption`),
      `QteMax` INT NOT NULL,
      CONSTRAINT `PK_VehOpt` PRIMARY KEY(`FK_Vehicule`,`FK_Option`)
    ) TYPE = INNODB CHARACTER SET latin1 COLLATE latin1_swedish_ci;
    Et voici la table qui ne se crée pas:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    CREATE TABLE t_QteOptLoc (
      `FK_Location` INT NOT NULL, CONSTRAINT `FK_Location_OL` FOREIGN KEY(`FK_Location`) REFERENCES `T_Location`(`IdLocation`),
      `FK_QteOptVeh` INT NOT NULL, CONSTRAINT `FK_Option_OL` FOREIGN KEY(`FK_QteOptVeh`) REFERENCES `T_QteOptVeh`(`FK_Vehicule`,`FK_Option`),
      `QteLouee` INT NOT NULL,
      PRIMARY KEY(`FK_Location`,`FK_QteOptVeh`)
    ) TYPE = INNODB CHARACTER SET latin1 COLLATE latin1_swedish_ci;
    J'ai chaque fois cette erreur: #1005 - Can't create table '.\nouvelle_db\t_qteoptloc.frm' (errno: 150)

    La deuxième clé étrangère de cette table correspond en fait a la clé primaire de la première table citée. Le problème c'est que la clé primaire est composée de 2 champs et je ne sais pas pourquoi il ne l'accepte pas ?

    Erreur dans un nom ou paramètre ???

    Merci

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

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

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 903
    Points : 6 027
    Points
    6 027
    Par défaut
    Erreur dans un nom ou paramètre ???
    ...ou erreur dans la modélisation... !

    D'où l'utilité de travailler avec un outil de modélisation dans lequel on "importe" les FK.
    Citation Envoyé par Manuel MySQL
    Les colonnes correspondantes de la contrainte dans la table et la table de référence doivent avoir le même type
    et dans ton exemple, tu as 1 INT d'un coté, et 2 de l'autre
    "Il n'y a pas de bonnes réponses à une mauvaise question." (M. Godet)
    -----------------------
    Pensez à cloturer votre sujet - Aucune réponse aux sollicitations techniques par MP
    Usus magister est optimus

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    245
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2002
    Messages : 245
    Points : 320
    Points
    320
    Par défaut
    Je dois modifier quoi vu que la clé primaire de la première table est composée de 2 champs ?????

    Et dans phpmyadmin, je n'ai pas l'option pour choisir la clé primaire composée des 2 champs. Ils sont listés tous les 2.

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

Discussions similaires

  1. Erreur 1064 CREATE TABLE avec cle reflexive
    Par ZuZu dans le forum Outils
    Réponses: 8
    Dernier message: 19/11/2007, 13h12
  2. probleme d'insertion dans table avec cle secondaire
    Par pseudobidon57 dans le forum SQL
    Réponses: 1
    Dernier message: 01/06/2007, 13h46
  3. Réponses: 3
    Dernier message: 24/04/2006, 21h03
  4. Probleme de création table avec PK et auto_increment
    Par slefevre01 dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 14/02/2006, 14h14
  5. supprimer une ligne avec cle etrangere
    Par BaBas dans le forum Langage SQL
    Réponses: 4
    Dernier message: 15/07/2003, 11h24

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