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

SQL Procédural MySQL Discussion :

Ajout contrainte FOREIGN KEY


Sujet :

SQL Procédural MySQL

  1. #1
    Membre régulier
    Inscrit en
    Janvier 2006
    Messages
    142
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 142
    Points : 73
    Points
    73
    Par défaut Ajout contrainte FOREIGN KEY
    bonjour,

    je souhaite créer une base de données sous mysql avec des tables qui contiennent des clés etrangères(FOREIGN KEY). j'ai besoin de renommer ces clé etrangères dans mes tables, et je ne sais pas comment indiquer que ces champs la sont des clés etrangére


    supposant que j'ai deux tables :

    client(id_client, nom, prenom..)
    achat(id_achat,id_acheteur...)

    sachant que "id_acheteur" doit etre une clé etrangère (= = 'id_client') comment indique ceci lors de la création de ma table achat??


    je sais que le code correspandant est par ex:
    ALTER TABLE `achat`
    ADD CONSTRAINT `fr_key1` FOREIGN KEY (`id_acheteur`) REFERENCES `client` (`id_client`) ON DELETE CASCADE ON UPDATE CASCADE;


    mais je ne vois pas ou metre ceci

    SVP aider moi c'est urgent
    merci.


    [Titre édité par Maximilian]

  2. #2
    Membre régulier
    Inscrit en
    Janvier 2006
    Messages
    142
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 142
    Points : 73
    Points
    73
    Par défaut clé etrangère
    bonjour,
    c'est bon , je viens de trouver la solution. en fat il falait choisir , lors de la création de la table, le type de table "innodb", et pour le champs qui doit etre clé etrangère et dont on affecter un autre nom, il faut lui donner propriété "index'.

    après on selectionne la table, on affiche sa structure, on clique sur le lien 'relation' (en bas) et on selectionne la clé principale à laquelle est liée cette clé etrangère.

    bon courage a tous

  3. #3
    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
    http://dev.mysql.com/doc/refman/5.0/fr/create-table.html

  4. #4
    Membre actif
    Inscrit en
    Septembre 2005
    Messages
    185
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 185
    Points : 220
    Points
    220
    Par défaut
    slt , je trouve ke t'as deux alternative.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    1-CREATE TABLE client (id_client  auto increment PRIMARY KEY,
     id_acheteur  integer FOREIGN KEY references achat(id_acheteur),
    prenom  char(32) NOT NULL,
    nom varchar(32) NOT NULL)
    2- si tu veux la renommer "id_acheteur" il te connaitre au préalable la contrainte puis la supprimer.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    ALTER TABLE client DROP CONSTRAINT nom_de _la_contrainte_par_default_de_sql  FOREIGN KEY references achat(id_acheteur) ensuite 
    l'ajoouter 
    ALTER TABLE client ADD CONSTRAINT nouveau_nom_de_la_contrainte FOREIGN KEY references achat(id_acheteur)
    la succession d'évènement que nous subissons toute notre vie n'est qu'un phénomène de compensation dont la nature en est l'arbitre.[Inéluctabilité de la nature ] Polace

  5. #5
    Membre régulier
    Inscrit en
    Janvier 2006
    Messages
    142
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 142
    Points : 73
    Points
    73
    Par défaut clé etrangère
    bonsoir,
    oui c'est bon , ça marche marci bcp pour votre aide. bon courage a tous.

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

Discussions similaires

  1. Clause match dans une contrainte foreign key
    Par Tordiame dans le forum Débuter
    Réponses: 1
    Dernier message: 05/07/2008, 20h24
  2. [phpMyAdmin] La contrainte FOREIGN KEY n'est jamais respectée
    Par Chatbour dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 8
    Dernier message: 30/06/2008, 12h31
  3. Erreur: conflit avec la contrainte FOREIGN KEY SAME TABLE
    Par useretl dans le forum Langage SQL
    Réponses: 2
    Dernier message: 25/10/2007, 12h27
  4. Contrainte, Foreign Key et erreur SQL
    Par zevince dans le forum PostgreSQL
    Réponses: 7
    Dernier message: 12/10/2007, 17h50
  5. Réponses: 3
    Dernier message: 13/07/2007, 09h32

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