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

PHP & Base de données Discussion :

problème de clé étrangère dans une table


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Juillet 2012
    Messages : 23
    Par défaut problème de clé étrangère dans une table
    Bonsoir tout le monde!!

    svp aidez moi

    j'ai trois tables:

    article(id_article,num,prix_achat,date_achat,duree_garantie,id_etr_agence,id_etr_marque)
    marque(id_marque,lib_marque)
    agence(id_agence,lib_agence)

    quand j'éxécute mon code ,j'ai ce message :
    Erreur : SQLSTATE[23000]: Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails (`gestion_articles`.`article`, CONSTRAINT `FK_article_id_marque` FOREIGN KEY (`id_etr_marque`) REFERENCES `marque` (`id_marque`))

    voilà mon code:

    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
    try
                   {
    	           $pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    	           $bdd = new PDO('mysql:host=localhost;dbname=gestion_articles', 'root', '', $pdo_options);
     
     
    					$req = $bdd->prepare('INSERT INTO agence(lib_agence) VALUES(:login,:lib_agence)');
     
     
                       $req->execute(array(
     
    				   'lib_agence' => $_POST['lib_agence'],
     
    	                ));
    					$req = $bdd->prepare('INSERT INTO marque(lib_marque) VALUES(:login,:lib_marque)');
     
     
                       $req->execute(array(
     
    				   'lib_marque' => $_POST['lib_marque'],
     
    	                ));
     
     
     
     
     
    $req = $bdd->prepare('INSERT INTO article(num,prix_achat,date_achat,duree_garantie)         VALUES(:login,:num,:prix_achat,:date_achat,:duree_garantie)');
     
     
     
     
    		$req->execute(array(
     
    				   'num' => $_POST['num'],
     
    				   'prix_achat' => $_POST['prix_achat'],
    				   'date_achat' => $_POST['date_achat'],
    				   'duree_garantie' => $_POST['duree_garantie'],
     
     
    				   ));
     
     
     
    				header("Location:acquisition.php ");
     
     
                    }
                    catch (Exception $e)
                    {
                    die('Erreur : ' . $e->getMessage());
                    }


    svp aidez moi ,je ne sais pas quoi faire

    Merci.

  2. #2
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Avril 2011
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2011
    Messages : 660
    Par défaut
    L'erreur est clair, tu essayes d'ajouter une ligne dans la table sauf que tu ne donnes pas une valeur dans le champ (`id_etr_marque`) qui doit être une REFERENCE à la table `marque` et au champ (`id_marque`))

    En gros, la valeur que tu passes dans id_etr_marque n'est pas dans la table marque ou est vide.

    Essaye de faire des écho pour voir ce que tu passes.

  3. #3
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    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 814
    Billets dans le blog
    14
    Par défaut
    Les requêtes d'insertion sont bizarres !
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO agence(lib_agence) VALUES(:login,:lib_agence)

    D'après ce que tu à écris, voici la structure de la table agence :
    agence(id_agence,lib_agence)
    Tu insères un login dans un identifiant qui devrait être un entier auto-incrémenté ?

    Idem pour les autres INSERT :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    INSERT INTO marque(lib_marque) VALUES(:login,:lib_marque)
     
    INSERT INTO article(num,prix_achat,date_achat,duree_garantie)         
    VALUES(:login,:num,:prix_achat,:date_achat,:duree_garantie)
    De plus, le paramètre :login n'est pas fourni à la requête !
    En fait je me demande même comment tu arrives jusqu'à l'erreur sur la troisième requête !

    Ensuite, avec ton code, tu vas insérer une agence et une marque à chaque fois que tu insères un article ?

    J'ai l'impression que tu peux tout refaire !
    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 !

Discussions similaires

  1. comment ajouter une clé étrangère dans une table
    Par une_tite_question dans le forum Débuter
    Réponses: 6
    Dernier message: 09/05/2008, 07h14
  2. Clé étrangéres dans une table Oracle
    Par Flipmode dans le forum Développement de jobs
    Réponses: 4
    Dernier message: 18/05/2007, 21h48
  3. Réponses: 2
    Dernier message: 14/05/2007, 10h45
  4. Definir une clé étrangère dans une table existante?
    Par gui38 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 15/12/2006, 13h54
  5. Réponses: 5
    Dernier message: 28/04/2006, 11h55

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