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

Requêtes MySQL Discussion :

Problème pour créer une clé étrangère


Sujet :

Requêtes MySQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 69
    Points : 47
    Points
    47
    Par défaut Problème pour créer une clé étrangère
    Bonjour, voici un extrait de mon script de création :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
     
     
    CREATE TABLE `membre` (
      `Id` int(10) unsigned NOT NULL auto_increment,
      `Nom` varchar(45) default NULL,
      `Prenom` varchar(45) default NULL,
      `email` varchar(45) default NULL,
      `photo` text,
      `equipe` varchar(45) default NULL,
      `tel` varchar(20) default NULL,
      `fax` varchar(20) default NULL,
      `bureau` varchar(5) NOT NULL default '',
      `id_statut` varchar(30) NOT NULL default '',
      `login` varchar(10) default NULL,
      `password` varchar(10) default NULL,
      PRIMARY KEY  (`Id`),
      FOREIGN KEY (`id_statut`) REFERENCES statut(`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=125 ;
     
    CREATE TABLE `statut` (
      `id` int(3) NOT NULL auto_increment,
      `lib_fr` varchar(30) NOT NULL default '',
      `lib_eng` varchar(30) NOT NULL default '',
      PRIMARY KEY  (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
    je voudrais donc créer une contrainte de référence avec l'id du statut entre l'id_statut du membre et l'id de la table statut.

    J'obtiens l'erreur suivante sous phpMyAdmin 2.6.1 à la création :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    Erreur
     
    requête SQL:
     
    -- 
    -- Structure de la table `membre`
    -- 
    CREATE TABLE `membre` (
    `Id` int( 10 ) unsigned NOT NULL AUTO_INCREMENT ,
    `Nom` varchar( 45 ) default NULL ,
    `Prenom` varchar( 45 ) default NULL ,
    `email` varchar( 45 ) default NULL ,
    `photo` text,
    `equipe` varchar( 45 ) default NULL ,
    `tel` varchar( 20 ) default NULL ,
    `fax` varchar( 20 ) default NULL ,
    `bureau` varchar( 5 ) NOT NULL default '',
    `id_statut` varchar( 30 ) NOT NULL default '',
    `login` varchar( 10 ) default NULL ,
    `password` varchar( 10 ) default NULL ,
    PRIMARY KEY ( `Id` ) ,
    KEY `id_statut` ( `id_statut` ) ,
    FOREIGN KEY ( id_statut ) REFERENCES statut( id )
    ) ENGINE = InnoDB DEFAULT CHARSET = latin1 AUTO_INCREMENT =125
     
    MySQL a répondu:
    #1005 - Ne peut cr�er la table '.\miv\membre.frm' (Errcode: 150)
    une idée ?

  2. #2
    Membre émérite Avatar de Maximil ian
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    2 622
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 2 622
    Points : 2 973
    Points
    2 973
    Par défaut
    Bonjour,

    Il faut que membre.id_statut et statut.id soient du même type, à savoir int(3).
    Pensez au bouton

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 69
    Points : 47
    Points
    47
    Par défaut
    Merci, j'ai corrigé cette faute d'inattention, j'ai mis tous les deux en int(3), mais j'obtiens toujours la même erreur

  4. #4
    Membre éprouvé
    Avatar de Biglo
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    537
    Détails du profil
    Informations personnelles :
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2002
    Messages : 537
    Points : 984
    Points
    984
    Par défaut
    Salut,

    Il faut créer la table statut avant la table membre. Ou insérer la contrainte référentielle par la suite avec un ALTER.

  5. #5
    Membre émérite Avatar de Maximil ian
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    2 622
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 2 622
    Points : 2 973
    Points
    2 973
    Par défaut
    En effet, je pensais que DevloNewb avait donné ses CREATE dans un ordre arbitraire. Il est évident que pour faire référence à une table il faut que celle-ci soit déjà créée
    Pensez au bouton

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 69
    Points : 47
    Points
    47
    Par défaut
    Merci ça marche !

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

Discussions similaires

  1. Problème pour créer une nomenclature
    Par astrid24 dans le forum Bibliographies - Index - Glossaires
    Réponses: 0
    Dernier message: 03/10/2007, 17h21
  2. [Débutant] Problèmes pour créer une classe
    Par Hokage dans le forum Débuter
    Réponses: 3
    Dernier message: 27/09/2007, 17h48
  3. problème pour créer une procédure stockée
    Par PoichOU dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 06/09/2007, 10h58
  4. [ANTLR/EXPRESS] Problèmes pour créer une grammaire de EXPRESS
    Par cotmar dans le forum Autres langages
    Réponses: 2
    Dernier message: 07/05/2007, 10h05
  5. Problème pour créer une illumination par dôme de lumière
    Par m-matthieu dans le forum Développement 2D, 3D et Jeux
    Réponses: 1
    Dernier message: 09/11/2006, 14h54

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