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

MySQL Discussion :

Mysql :Foreign key


Sujet :

MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Décembre 2009
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2009
    Messages : 107
    Par défaut Mysql :Foreign key
    Bonjour,

    Je souhaite créer une table matable2 en incluant une référence de l' id d'une autre table matable1.

    J'ai procédé comme suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE TABLE matable2(
    table2_id bigint(20),
    nom varchar(255),
    FOREIGN KEY(id_table1) REFERENCES matable1(id_table1)
    );
    et j'ai l'erreur suivante : 1072 Key column 'id_table1' doesn't exist in table.

    Merci d'avance

  2. #2
    Membre Expert Avatar de mactwist69
    Homme Profil pro
    Développement VB.NET
    Inscrit en
    Janvier 2007
    Messages
    1 707
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Développement VB.NET
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 707
    Par défaut
    Généralement, il faut indiquer les noms de la base de données ET la table.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE TABLE matable2(
    table2_id bigint(20),
    nom varchar(255),
    FOREIGN KEY(id_table1) REFERENCES `mabdd`.`matable1`(id_table1)
    );

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Décembre 2009
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2009
    Messages : 107
    Par défaut
    Bonjour,

    Je viens de le reprendre comme vous l'avez indiquer, et çà m'a afficher cette erreur:
    1064 you have an error in your sql syntax; check the manual that corresponds to your Mysql server version for the syntax to use 'mabase'.'matable1'.


    Dans le SGBD(Mysql) il y'a plusieurs bases de données , donc quand je tape une comme sans sélectionner d'abord l'une d'entre elles, Mysql me fait la remarque. Dans ce cas est-ce l'utilisation de 'mabase'.'matable1' est nécessaire?

    J'utilise Mysql Query Browser version 1.2.12

    Merci.

  4. #4
    Membre Expert Avatar de mactwist69
    Homme Profil pro
    Développement VB.NET
    Inscrit en
    Janvier 2007
    Messages
    1 707
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Développement VB.NET
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 707
    Par défaut
    Attention: Je n'ai pas utiliser " ' ", mais " ` " !

    Que tu obtiens avec AltGr + 7

    J'ai l'habitude de tout le temps les mettres, mais sinon, sans rien du tout ca devrai marché:


  5. #5
    Membre Expert Avatar de mactwist69
    Homme Profil pro
    Développement VB.NET
    Inscrit en
    Janvier 2007
    Messages
    1 707
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Développement VB.NET
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 707
    Par défaut
    Citation Envoyé par maparè Voir le message

    Dans le SGBD(Mysql) il y'a plusieurs bases de données , donc quand je tape une comme sans sélectionner d'abord l'une d'entre elles, Mysql me fait la remarque. Dans ce cas est-ce l'utilisation de 'mabase'.'matable1' est nécessaire?
    De ça... ce que je comprends, c'est dans un script si tu fais un

    ;

    alors pas besoin de faire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Create Table Mabdd.Matable
    Un: fonctionne.

    Mais en ce qui concerne la clé étrangère, je pense que d'indiquer la base de donnée ET la table est nécessaire.... Car plusieurs base de données et tables peuvent avoir le même nom de colonne, comme c'est ton cas d'ailleurs.

  6. #6
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 818
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 818
    Billets dans le blog
    14
    Par défaut
    Je pense que si la base est pré-sélectionnée, il n'est point besoin de préfixer la table par la base.

    j'ai l'erreur suivante : 1072 Key column 'id_table1' doesn't exist in table.
    Le message d'erreur indique que la colonne id_table1 n'existe pas dans une table.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE TABLE matable2(
    table2_id bigint(20),
    nom varchar(255),
    FOREIGN KEY(id_table1) REFERENCES matable1(id_table1)
    );
    En l'occurrence, cette colonne n'existe pas dans la table dans laquelle tu essaies de créer une clé étrangère.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  7. #7
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Décembre 2009
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2009
    Messages : 107
    Par défaut
    Bonjour,
    mactwist69 j'ai toujours utilisé

    CREATE TABLE matable.

    Pour ce qui est de `mabase`.`matable1`, Alt Gr + `7` ne marche pas avec mon clavier. Je ne sais pas si c'est parce que je travail sur un ecran virtuel (je me connecte sur le serveur via mon poste de travail pour utiliser la base Msql).

    CinePhil , pour ce passage : En l'occurrence, cette colonne n'existe pas dans la table dans laquelle tu essaies de créer une clé étrangère.


    Je pense puisque matable2 que j'essaye de créer n'existait pas, alors il n'est pas possible que cette colonne existe auparavant, plutôt après la création de la nouvelle table. Mais la colonne au quelle elle fait référence existe quand même dans matable1.

    Après vos suggestions j'ai réessayer mais je n'arrive toujours pas. Mais ce n'est qu'un début.

    Merci.

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

Discussions similaires

  1. problème Mysql foreign key
    Par lamini dans le forum Débuter
    Réponses: 5
    Dernier message: 19/03/2013, 13h39
  2. [mysql]table avec foreign key
    Par samjung dans le forum Langage SQL
    Réponses: 24
    Dernier message: 24/11/2005, 14h42
  3. Foreign Key sur Mysql
    Par lemagicien dans le forum Outils
    Réponses: 1
    Dernier message: 23/09/2005, 13h39
  4. mysql et foreign key
    Par skoukni_brahim dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 02/06/2005, 18h14
  5. foreign key dans mysql
    Par guillevin dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 08/04/2004, 15h07

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