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 1005 avec Foreign Key en InnoDB


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 1005 avec Foreign Key en InnoDB
    Bonjour,

    J'essaye de créer des tables avec des clés étrangères mais lorsque j'exécute mon script ca plante.

    J'ai recommencé avec un truc tout simple 2 table et ca plante aussi.

    Voici mon code SQL:
    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
     
    CREATE TABLE T_Localite (
      LocID INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
      CodePostal char(5) NOT NULL,
      Localite char(50) NOT NULL
    ) TYPE = INNODB CHARACTER SET latin1 COLLATE latin1_swedish_ci;
     
    CREATE TABLE T_Client (
      NumClient INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
      NomClient CHAR(50) NOT NULL,
      PrenomClient CHAR(50) NOT NULL,
      DateNaissance DATE,
      AdresseClient CHAR(100) NOT NULL,
      NumCarteIdentite CHAR(20) NOT NULL UNIQUE,
      NumTelephone CHAR(12),
      FK_Localite INT UNSIGNED NOT NULL, CONSTRAINT FK_Localite FOREIGN KEY(FK_Localite) REFERENCES T_Localite
      ) TYPE = INNODB CHARACTER SET latin1 COLLATE latin1_swedish_ci;
    Quand j'importe mon fichier .sql dans PhpMyAdmin ca plante avec le message:
    #1005 - Can't create table '.\baseessai\t_client.frm' (errno: 150)

    Ou pourrait-être mon erreur ?

    J'utilise la dernière version de Wamp (mysql 5 + php 5 + apache 2) le tout sous XP SP2

  2. #2
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 901
    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 901
    Points : 6 026
    Points
    6 026
    Par défaut
    REFERENCES T_Localite
    Tu ne donnes pas la colonne (LocID a priori)
    "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
    Merci, je vais essayer ca

  4. #4
    Membre expérimenté Avatar de davcha
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    1 258
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 258
    Points : 1 539
    Points
    1 539
    Par défaut
    Tiens, à ce propos... Quelqu'un sait si les devs de mysql ont prévu d'implémenter ON.... SET DEFAULT bientôt ?

  5. #5
    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
    OK ca fonctionne sans problème

  6. #6
    Nouveau Candidat au Club
    Inscrit en
    Novembre 2006
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 1
    Points : 1
    Points
    1
    Par défaut
    il suffit tout simplement de spécifier la colonne de référence dans le FOREIGN KEY, voir script.



    FK_Localite INT UNSIGNED NOT NULL, CONSTRAINT FK_Localite FOREIGN KEY(FK_Localite) REFERENCES T_Localite(locid)

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 22/07/2011, 15h09
  2. Réponses: 4
    Dernier message: 22/07/2009, 15h55
  3. Réponses: 6
    Dernier message: 14/05/2009, 11h01
  4. problème avec Foreign Key [Interbase 7.5] [Delphi 2005]
    Par xenos dans le forum Bases de données
    Réponses: 3
    Dernier message: 09/09/2005, 11h21
  5. Création d'une table avec foreign key
    Par lepierre dans le forum Langage SQL
    Réponses: 5
    Dernier message: 17/09/2004, 14h20

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