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

Langage PHP Discussion :

Double foreach qui me retourne un résultat erronné


Sujet :

Langage PHP

  1. #1
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut Double foreach qui me retourne un résultat erronné
    Bonjour à toutes et à tous,

    J'ai une table qui contient des résultats d'un sondages.

    Je voudrais afficher les résultats de ce sondage qui sont :

    Valeur 1 : 0 fois
    Valeur 2 : 2 fois
    Valeur 3 : 0 fois
    Valeur 4 : 1 fois

    Voici la requête toute simple qui récupère les résultats :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $sql = $dbh->prepare("SELECT reponse FROM vote WHERE titre=:titre");
        $data = array(':titre'=>'lieu_de_championat');
      //on rÈcupere le rÈsultat des anciens votes.
        $sql->execute($data);
     
        $cadre = $sql->fetchAll();
    J'obtiens cet array :


    Array
    (
    [0] => Array
    (
    [reponse] => 2
    [0] => 2
    )

    [1] => Array
    (
    [reponse] => 2
    [0] => 2
    )

    [2] => Array
    (
    [reponse] => 4
    [0] => 4
    )

    )
    Je voudrais donc compter le nombre de 2 (ici deux fois) et le nombre de 4 (ici 1 fois), j'utilise ce 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
     
    $totalreponse = array();
        foreach ($cadre as $key => $value)
        {
          foreach ($value as $key2 => $value2)
          {
              $index = $value2;
              if (array_key_exists($index, $totalreponse))
              {
                  $totalreponse[$index]++;
              }
              else
              {
                  $totalreponse[$index] = 1;
              }
          }
        }
    Le problème, est que j'obtiens des résultats qui sont doublés :

    - valeur 1 : 0.00% 0 vote.
    - valeur 2 : 133.33% 4 votes.
    - valeur 3 : 0.00% 0 vote.
    - valeur 4 : 66.66% 2 votes.
    Total votes : 3
    Comme vous pouvez le voir, j'obtiens à chaque fois le double de ce que j'ai réellement dans ma table.

    Voyez-vous le problème dans le double foreach svp ?

    Merci d'avance.

    bee

  2. #2
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut
    Problème résolu en choisissant PDO::FETCH_NUM ici :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $cadre = $sql->fetchAll(PDO::FETCH_NUM);

  3. #3
    Membre éprouvé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2012
    Messages
    631
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2012
    Messages : 631
    Points : 1 220
    Points
    1 220
    Par défaut
    tu pouvais aussi calculer le pourcentage depuis la requête en faisant un regroupement sur la response

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT count(reponse)/(SELECT COUNT(reponse) FROM vote) as percent FROM vote WHERE titre=:titre GROUP BY reponse

  4. #4
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut
    Merci pour cette solution alternative.

    Comme quoi, il y a souvent plusieurs solutions à un même problème.

    bee

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

Discussions similaires

  1. Requête qui ne retourne aucun résultat en timeout avec un top
    Par olysmar2 dans le forum Développement
    Réponses: 10
    Dernier message: 27/11/2014, 19h35
  2. [MySQL] Une requete qui ne retourne aucun résultats
    Par amerex dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 23/01/2010, 17h46
  3. Double Join qui ne retourne pas d'éléments
    Par jai_le_leu dans le forum Hibernate
    Réponses: 1
    Dernier message: 17/11/2008, 19h51
  4. [VB.NET] DataSet qui ne retourne pas de résultat
    Par Lois dans le forum Windows Forms
    Réponses: 4
    Dernier message: 02/06/2004, 17h07

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