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

Requêtes MySQL Discussion :

COUNT qui renvoie null au lieu de 0


Sujet :

Requêtes MySQL

  1. #1
    Membre régulier
    Inscrit en
    Mai 2007
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 183
    Points : 121
    Points
    121
    Par défaut COUNT qui renvoie null au lieu de 0
    Bonjour a tous,

    La requete SQL suivante retourne le nombre de réponses depuis les 25 derniers jours pour un utilisateur particulier.

    La requete fonctionne... mais quand il n'y a pas de réponse depuis les 25 derniers jours, le count me renvoie Null... mais moi je souhaiterais qu'il me retourne 0 !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    SELECT DATE_ADD(NOW(), INTERVAL - 600 HOUR ) INTO @var_dt_nowmoins25j;
     
    SELECT COUNT(DISTINCT DATE(`REPONSE`.`DT_REPONSE`))
    FROM `REPONSE` 
    WHERE
    	(`REPONSE`.`PSEUDO`='toto') 
    	AND
    	(TIMESTAMPDIFF(HOUR,@var_dt_nowmoins25j,`DT_REPONSE`)>=0) 
    	AND
    	(TIMESTAMPDIFF(HOUR,NOW(),`DT_REPONSE`)<=0) 
    GROUP BY `REPONSE`.`PSEUDO` ;
    C'est balo non ?

  2. #2
    Expert éminent
    Avatar de berceker united
    Profil pro
    SQL
    Inscrit en
    Février 2005
    Messages
    3 495
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : SQL
    Secteur : Finance

    Informations forums :
    Inscription : Février 2005
    Messages : 3 495
    Points : 6 067
    Points
    6 067
    Par défaut
    Afin de tester ta requête, vous pourrez retirer le COUNT(...). Ainsi, vous vérez si la requête est correcte. Mais par expérience, si elle vous retourne NULL c'est qu'il y a une erreur dans cette requête.

  3. #3
    Membre régulier
    Inscrit en
    Mai 2007
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 183
    Points : 121
    Points
    121
    Par défaut
    Si je remplace le COUNT par *, la requete me renvoit une ligne avec les champs avec la valeur nulle,
    Ce qui me parait normal puisque il n'y a aucune réponse (enregistrement dans la table réponse) dans la période demandée.
    Si il y a une ou plusieurs réponses, le count retourne bien une valeurs.

    Mais en définitive, je me demande si un count peut renvoyer la valeur 0.

  4. #4
    Expert éminent
    Avatar de berceker united
    Profil pro
    SQL
    Inscrit en
    Février 2005
    Messages
    3 495
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : SQL
    Secteur : Finance

    Informations forums :
    Inscription : Février 2005
    Messages : 3 495
    Points : 6 067
    Points
    6 067
    Par défaut
    si toute fois quand la requête renvois null vous souhaitiez que le count retourne zero, tentez d'utiliser la fonction IFNULL(COUNT(...),0). Pour plus de détail, regardez la doc sur IFNULL

  5. #5
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 737
    Points
    11 737
    Par défaut
    Normalement, le COUNT sur un requête vide renvoie 0. Peux-tu tester ta config avec cet exemple ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     select count(distinct toto) from (select 'toto' AS toto) tmp where toto = 'titi' ;

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

Discussions similaires

  1. Un getElementById qui renvoie null alors qu'il existe
    Par Marc22 dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 28/05/2010, 14h53
  2. [AC-2003] Requete qui renvoie 0 au lieu de NUll
    Par oxino dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 15/12/2009, 12h26
  3. Requête qui renvoie 'Null'
    Par Invit-é dans le forum VB 6 et antérieur
    Réponses: 14
    Dernier message: 11/06/2007, 17h32
  4. [SPL] Rewind() qui renvoie NULL
    Par fadeninev dans le forum Bibliothèques et frameworks
    Réponses: 6
    Dernier message: 06/06/2006, 15h44
  5. [JDBC]Un new qui renvoie null...
    Par Ditch dans le forum JDBC
    Réponses: 4
    Dernier message: 03/01/2005, 13h14

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