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 :

Soucis requête relation plusieurs à plusieurs [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Femme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2019
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Corse (Corse)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2019
    Messages : 48
    Par défaut Soucis requête relation plusieurs à plusieurs
    Bonjour,

    Je travaille actuellement sur la page qui permet d'ajouter un produit à la base de donnée. Un produit possède plusieurs ingrédients.
    J'ai créer une table intermédiaire parce qu'un produit peut contenir plusieurs ingrédients, mais ces ingrédients peuvent être partagés par plusieurs produits.

    Nom : table intermediaire.PNG
Affichages : 215
Taille : 61,5 Ko

    Dans le formulaire les ingrédients sont sous forme de case à cocher et identifier via leur nom. J'ai procédé comme cela car on peut ajouter des ingrédients dans la fiche produit via Ajax (on connait pas l'id à l'avance du coup).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
                <?php foreach ( $ingredients as $i ) : ?>
                    <div class="check">
                        <input type="checkbox" name="<?php echo $i['ing_name'] ?>">
                        <label class="ingredient" for="<?php echo $i['ing_name'] ?>"><?php echo $i['ing_name'] ?></label>
                    </div>
                <?php endforeach; ?>
                <div class="check" id="reponse-ajax"></div>
    Je ne sais pas comment faire maintenant pour insérer un produit avec tous ses ingrédients dans la bases de données. Est-ce que quelqu'un pourrait m'aider ?
    ps : je me sers des requêtes préparées

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    1- OK pour les 3 tables en BDD.

    2- Mauvaise méthode pour les checkbox.
    Il faut écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                        <input type="checkbox" name="ingredient_ids[]" value="<?php echo $i['ing_id'] ?>" />
    3- On récupère les cases COCHÉES avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $ingredient_ids = $_POST['ingredient_ids']; // array des ing_id COCHES
    4- Enregistrement : dans la table "lier_........"
    4a- d'ABORD, on SUPPRIME les anciennes relations :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "DELETE FROM lier_........ WHERE p_id = ?"
    4b-Ensuite, on enregistre les nouvelles relations :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $sql_insert = "INSERT INTO lier_........ (p_id, ing_id) VALUES (?, ?)";
    $pdo_insert = $pdo->prepare($sql_insert);
    foreach( $ingredient_ids as $ing_id )
    {
       $pdo_insert->execute(array($p_id, $ing_id));
    }

  3. #3
    Membre averti
    Femme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2019
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Corse (Corse)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2019
    Messages : 48
    Par défaut
    Coucou merci pour ta réponse
    J'ai corrigé pour les checkboxs. Par contre, vu qu'on ajoute un nouveau produit à la base de données, comment je fais pour récupérer l'id avant de le passer à la requête ?

  4. #4
    Invité
    Invité(e)

  5. #5
    Membre averti
    Femme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2019
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Corse (Corse)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2019
    Messages : 48
    Par défaut
    Merci jreaux62 ça marche parfaitement

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

Discussions similaires

  1. Requête relation plusieurs à plusieurs
    Par LO88ra dans le forum Requêtes
    Réponses: 3
    Dernier message: 16/08/2019, 11h13
  2. [Toutes versions] Requêtes relation UN à PLUSIEURS
    Par lili2006 dans le forum Access
    Réponses: 20
    Dernier message: 09/05/2016, 23h12
  3. Requête spéciale dans le cas d'une relation plusieurs à plusieurs
    Par Chauve souris dans le forum Langage SQL
    Réponses: 5
    Dernier message: 03/05/2013, 21h32
  4. Réponses: 3
    Dernier message: 02/03/2011, 16h30
  5. Réponses: 6
    Dernier message: 28/06/2010, 13h04

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