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 :

probleme sur les clés étrangere


Sujet :

MySQL

  1. #1
    Candidat au Club
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juillet 2015
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2015
    Messages : 1
    Points : 4
    Points
    4
    Par défaut probleme sur les clés étrangere
    Bonjour à tous je rencontre un problème lord de la création d'une table qui contient une clé étrangère voici les codes source de mes différentes tables

    table 1

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE TABLE  Client (
      `id_client` int(11) NOT NULL AUTO_INCREMENT,
      `nom` varchar(12) NOT NULL,
      PRIMARY KEY (`id_client`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
    Table 2

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    CREATE TABLE  Commandes (
      `id_commandes` int(11) NOT NULL AUTO_INCREMENT,
      `id_client` int(11) NOT NULL,
      `produit` varchar(20) NOT NULL,
      PRIMARY KEY (`id_commandes`),
     FOREIGN KEY(`id_client') REFERENCES Client(`id_client`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
    lords de la compilation de cette dernière table le massage suivant est générer : " impossible d'ajouter une contrainte d'index externe"
    Merci de bien vouloir m'aider merci

  2. #2
    Membre chevronné

    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    974
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 974
    Points : 1 825
    Points
    1 825
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    FOREIGN KEY(`id_client`) REFERENCES Client(`id_client`)

  3. #3
    Expert éminent sénior Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 381
    Points : 19 064
    Points
    19 064
    Par défaut
    Salut emmanueleyike.

    Vous avez deux problèmes.

    1) la solution est donné par 'plawyx", mais il n'est pas très visible à l'écran.
    Vous avez mis une apostrophe droite au lieu de l'apostrophe oblique après le premier 'id-client'.
    Normalement, cela vous fait une erreur de syntaxe.

    2) En cas d'insertion d'une nouvelle ligne dans la table des commandes, vous pouvez obtenir un message d'anomalie concernant la contrainte sur la clef étrangère.
    Vous devez vous assurer que la valeur de la colonne 'id_client', puisque c'est une clef étrangère, existe bien dans la table 'client'.
    Je vous donne en exemple, le mécanisme de rejet lors de l'insertion d'une ligne n'ayant pas la valeur indiqué dans la table 'client'.

    Vous devez abord insérer toutes les lignes dont vous avez besoin dans la table 'client', avant d'insérer celles dans la table 'commande'.

    Quand vous devez utiliser une clef étrangère avec des restrictions d'accès, vous devez :
    a) pour la suppression, vous devez d'abord supprimer les lignes de la table 'commandes' avant celle de la table 'client'.
    b) pour la modification, vous devez d'abord insérer une nouvelle ligne dans la table 'client', puis venir modifier celle de la table 'commandes'.
    Bon en gros, c'est lourd à faire et ça prend du temps.

    Si vous utilisez la syntaxe suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    FOREIGN KEY(`id_client`) REFERENCES `Client` (`id_client`) ON UPDATE CASCADE ON DELETE CASCADE
    Vous pouvez supprimer les lignes de la table 'client' en premier et celle de la table 'commande' se feront automatiquement.
    Vous pouvez, de même, faire des modifications dans la table 'client' en premier et avoir une répercussion dans la table 'commande'.
    Je vous donne les exemples de ce mécanisme ci-après :

    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    --------------
    SET AUTOCOMMIT = 0
    --------------
     
    --------------
    START TRANSACTION
    --------------
     
    --------------
    DROP DATABASE IF EXISTS `base`
    --------------
     
    --------------
    CREATE DATABASE `base`
            DEFAULT CHARACTER SET `latin1`
            DEFAULT COLLATE       `latin1_general_ci`
    --------------
     
    --------------
    DROP TABLE IF EXISTS `Client`
    --------------
     
    --------------
    CREATE TABLE Client (
      `id_client` int(11)     NOT NULL AUTO_INCREMENT,
      `nom`       varchar(12) NOT NULL,
      PRIMARY KEY (`id_client`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1
    --------------
     
    --------------
    INSERT INTO `Client` (`nom`) VALUES
    ('albert'), ('marcel'), ('léon'), ('alfred')
    --------------
     
    --------------
    select * from client
    --------------
     
    +-----------+--------+
    | id_client | nom    |
    +-----------+--------+
    |         1 | albert |
    |         2 | marcel |
    |         3 | léon   |
    |         4 | alfred |
    +-----------+--------+
    --------------
    DROP TABLE IF EXISTS `Commandes`
    --------------
     
    --------------
    CREATE TABLE Commandes (
      `id_commandes` int(11) NOT NULL AUTO_INCREMENT,
      `id_client`    int(11) NOT NULL,
      `produit`      varchar(20) NOT NULL,
      PRIMARY KEY (`id_commandes`),
      FOREIGN KEY(`id_client`) REFERENCES `Client` (`id_client`) ON UPDATE CASCADE ON DELETE CASCADE
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1
    --------------
     
    --------------
    INSERT INTO `Commandes` (`id_client`, `produit`) VALUES
    (2, 'machin'), (4, 'truc'), (4, 'chose')
    --------------
     
    --------------
    select * from commandes
    --------------
     
    +--------------+-----------+---------+
    | id_commandes | id_client | produit |
    +--------------+-----------+---------+
    |            1 |         2 | machin  |
    |            2 |         4 | truc    |
    |            3 |         4 | chose   |
    +--------------+-----------+---------+
    --------------
    INSERT INTO `Commandes` (`id_client`, `produit`) VALUES
    (5, 'bidule')
    --------------
     
    ERROR 1452 (23000) at line 72: Cannot add or update a child row: a foreign key constraint fails (`base`.`commandes`, CONSTRAINT `commandes_ibfk_1` FOREIGN KEY (`id_client`) REFERENCES `client` (`id_cl
    ient`) ON DELETE CASCADE ON UPDATE CASCADE)
    --------------
    select * from commandes
    --------------
     
    +--------------+-----------+---------+
    | id_commandes | id_client | produit |
    +--------------+-----------+---------+
    |            1 |         2 | machin  |
    |            2 |         4 | truc    |
    |            3 |         4 | chose   |
    +--------------+-----------+---------+
    --------------
    update `client` set id_client = 33 where id_client = 4
    --------------
     
    --------------
    select * from client
    --------------
     
    +-----------+--------+
    | id_client | nom    |
    +-----------+--------+
    |         1 | albert |
    |         2 | marcel |
    |         3 | léon   |
    |        33 | alfred |
    +-----------+--------+
    --------------
    select * from commandes
    --------------
     
    +--------------+-----------+---------+
    | id_commandes | id_client | produit |
    +--------------+-----------+---------+
    |            1 |         2 | machin  |
    |            2 |        33 | truc    |
    |            3 |        33 | chose   |
    +--------------+-----------+---------+
    --------------
    delete from `client` where id_client = 33
    --------------
     
    --------------
    select * from client
    --------------
     
    +-----------+--------+
    | id_client | nom    |
    +-----------+--------+
    |         1 | albert |
    |         2 | marcel |
    |         3 | léon   |
    +-----------+--------+
    --------------
    select * from commandes
    --------------
     
    +--------------+-----------+---------+
    | id_commandes | id_client | produit |
    +--------------+-----------+---------+
    |            1 |         2 | machin  |
    +--------------+-----------+---------+
    --------------
    COMMIT
    --------------
     
    --------------
    SET AUTOCOMMIT = 1
    --------------
     
     
    Appuyez sur une touche pour continuer...
    @+
    Si vous êtes de mon aide, vous pouvez cliquer sur .
    Mon site : http://www.jcz.fr

Discussions similaires

  1. Questions sur les clés de registre
    Par cjacquel dans le forum MFC
    Réponses: 1
    Dernier message: 30/04/2005, 19h12
  2. [Hashtable] Question sur les clés
    Par chabannou dans le forum Collection et Stream
    Réponses: 2
    Dernier message: 24/04/2005, 18h40
  3. [C#] Probleme sur les clés primaires composites
    Par stardeus dans le forum Windows Forms
    Réponses: 7
    Dernier message: 12/02/2005, 23h28
  4. MS Access et TQuery (probleme sur les dates)
    Par Djob dans le forum C++Builder
    Réponses: 4
    Dernier message: 15/06/2004, 14h57
  5. Probleme sur les chaines de caractere
    Par scorpiwolf dans le forum C
    Réponses: 8
    Dernier message: 06/05/2002, 19h01

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