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 :

Afficher 0 dans les résultats count(*) [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2015
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Drôme (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Septembre 2015
    Messages : 20
    Par défaut Afficher 0 dans les résultats count(*)
    Bonjour

    voici ma requête , qui compte le nombre de clients dans chaque groupe.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $req = $bdd->prepare('SELECT gl.name, c.id_default_group, count(*) as nb FROM prstshp_customer c LEFT JOIN prstshp_group_lang gl ON c.id_default_group=gl.id_group 
    		WHERE gl.id_lang=2 and MONTH(date_add)=:mois_aff and YEAR(date_add)=:annee 
    		GROUP BY c.id_default_group');
    		$req->bindValue(':mois_aff', $mois_aff);
    		$req->bindValue(':annee', $annee);
    		$req->execute();
    		while($row=$req->fetch(PDO::FETCH_OBJ)) {
    			echo '<tr><td>'.$row->name.'</td><td align="right">'.$row->nb.'</td></tr>';
    		}
    je souhaite afficher le zéro de count(*), car pour l'instant ca n'affiche que les groupes qui ont des clients

    Merci

  2. #2
    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 : 59
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Billets dans le blog
    8
    Par défaut
    Il affiche quoi ? null au lieu de zéro ?
    Si c'est le cas, essaie ceci

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT gl.name, c.id_default_group, ifnull(0,count(*)) as nb
    FROM prstshp_customer c 
    LEFT JOIN prstshp_group_lang gl ON c.id_default_group=gl.id_group 
    WHERE gl.id_lang=2 
    and MONTH(date_add)=:mois_aff 
    and YEAR(date_add)=:annee 
    GROUP BY c.id_default_group
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2015
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Drôme (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Septembre 2015
    Messages : 20
    Par défaut
    Avec ta solution ca met des zeros de partout, ca ne fonctionne pas...

    Dans mon script je fais une boucle pour avoir des résultats sur plusieurs mois.
    Ca n'affiche pas Null ca ne met pas de ligne tout simplement.

    Janvier
    GP1 = 5
    GP2 = 4
    GP3 = 6

    Fevrier
    GP1=8
    GP2=3
    GP4=2
    GP5=7

    Mars
    GP3=5

    Avril
    GP2=5
    GP8=9


    J'aimerai afficher chaque groupe , et si 0 alors que ca m'affiche GP=0

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

    tu ne peux pas afficher des lignes (ni le count) si elles sont exclus de ta requêtes, ou si elles n'existent pas dans la table !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    		WHERE gl.id_lang=2 and MONTH(date_add)=:mois_aff and YEAR(date_add)=:annee
    Si, dans la table, tu n'as pas d'enregistrement en février pour le GP3 (par exemple), il n'y a aucune chance que ce soit comptabilisé dans la requête, puisque ça n'existe tout simplement pas.

    Si ce que tu veux c'est afficher TOUS les groupes (GP) pour tous les mois, il faut sans doute faire 2 requêtes.

    [EDIT] As-tu essayer de remplacer "LEFT JOIN" par "RIGHT JOIN" ou "FULL JOIN" ?
    Dernière modification par Invité ; 04/05/2016 à 17h45.

  5. #5
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2015
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Drôme (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Septembre 2015
    Messages : 20
    Par défaut
    Oui en février je n'ai pas de client du groupe 3, le count devrait donc renvoyé 0 ?! GP3=0 ca me parait logique puisqu'il compte...

    Il y doit y avoir une autre solution que le faire en 2 requetes.

  6. #6
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    Et avec :
    à la place du count ?
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

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

Discussions similaires

  1. Supprimer le double backslash dans les résultats SQL
    Par stephane.julien dans le forum C#
    Réponses: 12
    Dernier message: 24/09/2007, 10h53
  2. Ne pas obtenir de doublons dans les résultats.
    Par Premium dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 26/06/2007, 14h58
  3. Réponses: 4
    Dernier message: 12/11/2006, 18h49
  4. Aberration dans les résultat d'un SELECT
    Par tpatrice2003 dans le forum Oracle
    Réponses: 1
    Dernier message: 13/06/2006, 09h43
  5. Requête SELECT problème dans les résultats trouvés ...
    Par snoopy69 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 18/10/2005, 12h46

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