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 :

Insérer une valeur dans deux tables [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Candidat au Club
    Homme Profil pro
    autre
    Inscrit en
    Octobre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : autre
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut Insérer une valeur dans deux tables
    Bonjour, je souhaite insérer une valeur dans 2 tables.
    Ici je voudrais que l'id du jeu de la première table soit inséré également dans le champ id_jeux de la seconde table (je ne sais pas si je suis très clair)

    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
     
    <?php
    try
    {
        $bdd = new PDO('mysql:host=localhost;dbname=mabb', 'root', '');
    }
    catch(Exception $e)
    {
            die('Erreur : '.$e->getMessage());
    }
    ?>
    <?php 
    if (isset($_POST['nom']) AND isset($_POST['console']) AND isset($_POST['prix']) AND isset($_POST['proprio'])){
    	$nom = $_POST['nom'];
    	$console = $_POST['console'];
    	$prix = $_POST['prix'];
    	$nomproprio = $_POST['proprio'];
    	$query_one = "INSERT INTO jeux_videos(nom, console, prix) VALUES(:nom, :console, :prix)";
        $sql_query_one = mysqli_query($bdd,$query_one);
     
            if ($sql_query_one) {
                $id = mysqli_insert_id($bdd);
                $query_two = "INSERT INTO proprietaire (id,id_jeux,nom) VALUES ('', :id, :nomproprio)";
                $sql_query_two = mysqli_query($bdd, $query_two);
            }
    }
    ?>
    <form action="index.php" method="post">
    <input type="text" name="nom" placeholder="nom du jeu"/><br>
    <input type="text" name="proprio" placeholder="votre nom"/><br>
    <input type="text" name="console" placeholder="console"/><br>
    <input type="text" name="prix" placeholder="prix"/><br>
    <input type="submit" value="envoyer"/>
    </form>
    Merci de m'éclairer si quelqu'un a une idée

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Ton code mélange du mysqli et du PDO, forcemment ça coince.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Candidat au Club
    Homme Profil pro
    autre
    Inscrit en
    Octobre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : autre
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    Merci pour ta réponse du coup j'ai revu mon code (bon c'est pas encore ça parce que j'ai des erreurs mais peux tu me dire si je suis sur la bonne voie?)

    modifs apportées :

    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
     
    <?php
    try
    {
        $bdd = new PDO('mysql:host=localhost;dbname=mabdd', 'root', '');
    }
    catch(Exception $e)
    {
            die('Erreur : '.$e->getMessage());
    }
    ?>
    <?php 
    if (isset($_POST['nom']) AND isset($_POST['console']) AND isset($_POST['prix']) AND isset($_POST['proprio'])){
    	$nom = $_POST['nom'];
    	$console = $_POST['console'];
    	$prix = $_POST['prix'];
    	$nomproprio = $_POST['proprio'];
    	$ajouterjeux = $bdd->prepare('INSERT INTO jeux_videos(nom, console, prix) VALUES(:nom, :console, :prix)');
    	$ajouterjeux->execute(array(
        'nom' => $nom,
        'console' => $console,
        'prix' => $prix
        ));
     
            if ($ajouterjeux) {
    			$bdd->lastInsertId();
                $ajouterproprio = $bdd->prepare('INSERT INTO proprietaire (id_jeux,nom) VALUES (:id, :nomproprio)');
                $ajouterproprio->execute(array(
    			'id_jeux' => $id,
    			'proprio' => $nomproprio
    			));
            }
    }
    ?>
    <form action="index.php" method="post">
    <input type="text" name="nom" placeholder="nom du jeu"/><br>
    <input type="text" name="proprio" placeholder="votre nom"/><br>
    <input type="text" name="console" placeholder="console"/><br>
    <input type="text" name="prix" placeholder="prix"/><br>
    <input type="submit" value="envoyer"/>
    </form>
    J'ai oublié de précisé les erreurs que je rencontre.. :

    Notice: Undefined variable: id in ligne 28
    et
    Warning: PDOStatement::execute(): SQLSTATE[HY093]: Invalid parameter number: parameter was not defined in ligne 30

    pour la première erreur c'est à cause de l'id du jeu que je n'arrive pas à récupérer, non?

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Non c'est parce que tu n'as nul part $id = .....
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Candidat au Club
    Homme Profil pro
    autre
    Inscrit en
    Octobre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : autre
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    Et comment est ce que je peux l'obtenir? tu peux me diriger sur une piste?

  6. #6
    Membre expert
    Avatar de Spartacusply
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 1 723
    Points : 3 274
    Points
    3 274
    Par défaut
    Comme ceci par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $id = $bdd->lastInsertId();
    Un message utile vous a aidé ? N'oubliez pas le

    www.simplifions.fr - Simplifier vos comptes entre amis !

  7. #7
    Candidat au Club
    Homme Profil pro
    autre
    Inscrit en
    Octobre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : autre
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    Ok merci du coup je l'ai intégré et je n'ai plus la première erreur.
    Par contre je ne comprend pas la deuxième erreur :

    Warning: PDOStatement::execute(): SQLSTATE[HY093]: Invalid parameter number: parameter was not defined in

    voici le code avec la correction (je ne mets que le php) :
    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
     
    <?php 
    if (isset($_POST['nom']) AND isset($_POST['console']) AND isset($_POST['prix']) AND isset($_POST['proprio'])){
    	$nom = $_POST['nom'];
    	$console = $_POST['console'];
    	$prix = $_POST['prix'];
    	$nomproprio = $_POST['proprio'];
    	$ajouterjeux = $bdd->prepare('INSERT INTO jeux_videos(nom, console, prix) VALUES(:nom, :console, :prix)');
    	$ajouterjeux->execute(array(
        'nom' => $nom,
        'console' => $console,
        'prix' => $prix
        ));
     
            if ($ajouterjeux) {
    			$id = $bdd->lastInsertId();
                $ajouterproprio = $bdd->prepare('INSERT INTO proprietaire (id_jeux,nom) VALUES (:id, :nomproprio)');
                $ajouterproprio->execute(array(
    			'id_jeux' => $id,
    			'proprio' => $nomproprio
    			));
            }
    }
    ?>
    Merci encore pour vos contributions

  8. #8
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    proprio ou nomproprio ? il faut choisir.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     $ajouterproprio = $bdd->prepare('INSERT INTO proprietaire (id_jeux,nom) VALUES (:id_jeux, :nomproprio)');
                $ajouterproprio->execute(array(
    			'id_jeux' => $id,
    			'nomproprio' => $nomproprio
    			));
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  9. #9
    Membre expert
    Avatar de Spartacusply
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 1 723
    Points : 3 274
    Points
    3 274
    Par défaut
    De même avec id, i_jeux d'ailleurs
    Un message utile vous a aidé ? N'oubliez pas le

    www.simplifions.fr - Simplifier vos comptes entre amis !

  10. #10
    Candidat au Club
    Homme Profil pro
    autre
    Inscrit en
    Octobre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : autre
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    Merci pour votre aide c'est plus clair pour moi maintenant

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

Discussions similaires

  1. [WD19] Insérer une valeur dans un champ Table
    Par Térence01 dans le forum WinDev
    Réponses: 7
    Dernier message: 06/05/2014, 10h07
  2. Insérer une checkbox dans un Table en JS
    Par lekunfry dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 08/08/2007, 17h06
  3. problem avec la recherche d'une valeur dans les table
    Par anilane dans le forum Bases de données
    Réponses: 6
    Dernier message: 25/05/2007, 19h35
  4. Réponses: 2
    Dernier message: 25/01/2007, 11h34
  5. Probleme pour insérer une valeur dans une bdd
    Par gaetan.tranvouez dans le forum VB 6 et antérieur
    Réponses: 16
    Dernier message: 30/05/2006, 10h58

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