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 :

mon resutat est tronqué? [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut mon resutat est tronqué?
    Bonjour a tous

    je suis entraint de crée un script qui récupère un panier qui est dans une session et je l'affiche à traver un tableau, j'ai un souci, quand j'affiche le résultat d'une quantié il m'indique 7 à la place de 777 voici le script:

    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
     
    <?php 
    session_start();
     
      //--------------------------------loger la base
    //securisation de la bdd pour les injections sql
     
    	foreach($_SESSION['panier'] as $clef =>$valeur)
    {
    	echo "le numéro $clef à été commander $valeur fois<br/>";
    }
    echo"quantite 26=".'<br/>';
         $laquantite=$_SESSION['panier'][26]['quantite'];
    echo $laquantite;
    echo '<br/>';
    var_dump($_SESSION['panier']);
    ?>
     
     
    <!-- preparation de ma table-->
    <table border=1>
    <tr>
    <td>numéro de l'article</td><td>designation</td><td>prix unitaire</td><td>quantite</td><td>sous total HT</td>
    </tr>
    <?php
    //récupération des données de la table _rdvs + _clients
    $select_article='SELECT * FROM _articles WHERE id_article IN ('.implode(',',array_keys($_SESSION['panier'])).')';
    $sql_article= mysql_query($select_article);
     
     
    while($recup_article=mysql_fetch_array($sql_article))
    {
    $id_article=$recup_article['id_article'];
    $designation=$recup_article['designation'];
    $pu=$recup_article['pu'];
    $code_barre=$recup_article['code_barre'];
    echo"<tr><td>$id_article</td>
    <td>$designation</td>
    <td>$pu</td>
    <td>";
    //ici je veux afficher la quantité qui est dans mon panier.
    $laquantite=$_SESSION['panier'][$id_article];
    echo $laquantite;
    echo '</td>
    <td>sous total</td></tr>';
    }
    ?>
    </table>
    voici ce qu'il affiche avec la boucle foreach:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    le numéro 26 à été commander 777888 fois
    le numéro 25 à été commander 777 fois
    le numéro 24 à été commander 5 fois
    </code>
    voici ce qu'il affiche echo $laquantite:
    quantite 26=
    7
    la normalement il devrai afficher 777888
    [code]
    voici ce que j'ai dans var_dump:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    array(3) { [26]=> string(6) "777888" [25]=> string(3) "777" [24]=> string(1) "5" }
    ai-je bien utiliser la bonne méthode pour trouver la quantité? sinon comment s'y prendre pour affichier correctement la quantite?
    merci d'avance de vos aident

  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
    Par défaut
    Ta quantité pour l'article 26 est $_SESSION['panier'][26] ; $_SESSION['panier'][26]['quantite'] n'existe pas comme tu peux le voir.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut
    merci de ton aide sabotage

    dans mon panier si quantité enrgistré égale à 1 à 9 cela affiche correctement le résultat par contre si je remplis mon panier par un
    777 affiche 7
    589 affiche 5
    856 affiche 8 etc...
    ce résultat correspond à $laquantite.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $laquantite=$_SESSION['panier'][$id_article]['quantite'];
    $id_article sera églale à 26 pour voir si le résultat est correcte,
    elle existera car j'aurai choisi l'article don son id_article sera égale à 26
    j'ai crée ce scipt et mis un 26 pour mes test pour voir si le résultat était correcte
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    echo"quantite 26=".'<br/>';
         $laquantite=$_SESSION['panier'][26]['quantite'];
    echo $laquantite;
    le 26 de cette ligne
    $laquantite=$_SESSION['panier'][26]['quantite'];

    ne correponde pas a ce 26? comment faut t'il que je procède

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    array(3) { [26]=> string(6) "777888"
    voici comment est contruit la quantite:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $_SESSION['panier'][$_POST['id_article']] = $_POST['quantite'];

  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
    Par défaut
    $laquantite=$_SESSION['panier'][26]['quantite'];

    ne correponde pas a ce 26? comment faut t'il que je procède
    Je t'ai répondu : c'est $_SESSION['panier'][26] car il n'y a pas l'index 'quantité' dans ton panier en session.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut
    en y pensant effectivement php ne peut pas deviner l'index (eu cela s'appelle aussi la clef?) avec $_SESSION['panier'].
    il faut que je je remplis entre crochetf

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $laquantite=$_SESSION[0][26]['quantite'];
    dans ma boucle pense tu que $laquantité a toute les donnée necessaire donnée une réponse correcte
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $laquantite=$_SESSION['panier'][$id_article]['quantite'];
    j'ai refait mes test en mettant l'index voici le résulta des tous les echo
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    le numéro 26 à été commander 859 fois
    le numéro 24 à été commander 1 fois
    le numéro 19 à été commander 555 fois
    quantite 26=
    8
    array(3) { [26]=> string(3) "859" [24]=> string(1) "1" [19]=> string(3) "555" }
    il m'affiche quantité 26= 8 au lieu de 859?

  6. #6
    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
    Par défaut
    Je crois que tu n'y es toujours pas

    Pour reprendre ton exemple du début, dans ta session il y a :
    $_SESSION['panier'][26] = "777888"
    $_SESSION['panier'][25] = "777"
    $_SESSION['panier'][24] = "5"
    'quantite' n'existe pas.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

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

Discussions similaires

  1. [Pattern][Regex] vérifier que mon email est valide
    Par anitshka dans le forum Collection et Stream
    Réponses: 7
    Dernier message: 23/05/2011, 13h03
  2. mon exportation est tronquée
    Par sbsbsbsb dans le forum Intégration
    Réponses: 0
    Dernier message: 01/05/2009, 01h11
  3. mon poste est invisible depuis le serveur
    Par StyleXP dans le forum Administration
    Réponses: 13
    Dernier message: 08/01/2006, 22h32
  4. [Sécurité] Savoir si mon visiteur est un humain
    Par toure32 dans le forum Langage
    Réponses: 8
    Dernier message: 08/01/2006, 15h13
  5. [Access] Mon application est détruite !!!
    Par mathias dans le forum Access
    Réponses: 4
    Dernier message: 26/06/2003, 14h14

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