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 :

remplir plusieurs tables ensemble [MySQL]


Sujet :

PHP & Base de données

  1. #21
    Invité
    Invité(e)
    Par défaut
    Alors :

    • Indente proprement ton code : on y verra plus clair
    • Ajoute des commentaires : on saura ce qui s'y passe (et l'ordre des actions)

  2. #22
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Tu as un problème de conception : tu retransmets l'id du produit sélectionné par formulaire lorsque tu demandes à ton utilisateur de confirmer ses coordonnées. Ce n'est pas nécessaire, vu que les ids en question sont dans le panier dans la session.

    Donc en fait, il faut virer le for sur lequel le dalmatien et toi vous prenez le chou depuis 20 posts, et ajouter une boucle sur le panier au moment de l'enregistrement :

    Quelque chose comme ça :
    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
    $req3 = $bdd->prepare('INSERT INTO produits_commandes(nomp, quantite, prixu, prixtotal, idcmd) VALUES(:nomp, :quantite, :prixu, :prixtotal, :last_id_in_commande)');
     
        $count = count($_SESSION['achats']);
        for ($i = 0; $i < $count; $i++) {
            // pour chaque produit du panier : 
            if ($_SESSION['achats'][$i]['statut'] != 0) {
                $id = $_SESSION['achats'][$i]['id1']; // on recupère l'id  
                // on l'insère en base :
                $req3->execute(array(
                    ':nomp' => $lig3['nom'],
                    ':quantite' => $qte,
                    ':prixu' => $prix,
                    ':prixtotal' => $tot,
                    ':last_id_in_commande' => $last_id_in_commande
        ));
    Sauf que la requête a l'air bizarre :
    - normalement, tu devrais avoir l'id du produit dedans (à la place du nom)
    - stocker le prix total si tu as déjà le prix unitaire et la quantité, c'est redondant, donc inutile (si tu veux récupérer le prix total, il te suffira de faire le calcul dans la requête récupération)
    - d'où sortent prix et quantité ? il faut les récupérer dans la session et/ou la base pour chaque produit présent dans le panier.

    Donc il faudrait ajuster la requête et la base pour corriger ça, mais l'idée générale est là : une insertion par produit dans le panier, et pas de transmission par formulaire.
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Remplir plusieurs tables avec un formulaire unique
    Par cedre06130 dans le forum IHM
    Réponses: 4
    Dernier message: 14/08/2020, 02h07
  2. Réponses: 6
    Dernier message: 17/05/2013, 11h52
  3. [AC-2007] Formulaire pour remplir plusieurs tables (débutante access)
    Par korentine dans le forum IHM
    Réponses: 2
    Dernier message: 23/07/2010, 14h40
  4. Réponses: 2
    Dernier message: 11/04/2007, 13h14
  5. Réponses: 19
    Dernier message: 13/03/2006, 14h06

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