2010-05-10 7 views
5

J'essaie de créer SELECT déclaration avec une clause GROUP BY, qui devrait renvoyer "valeurs par défaut".SQL GROUP BY avec "valeurs par défaut"

Imaginez la table MySQL simple:

CREATE TABLE `tracker` (
    `id` INTEGER PRIMARY KEY auto_increment, 
    `date` DATETIME NOT NULL, 
    `customer_id` INTEGER NOT NULL 
); 

Le tableau ne contient qu'un seul enregistrement:

INSERT INTO `tracker` (`date`, `customer_id`) VALUES('2010-05-03', 1); 

Après salles J'exécution de la requête SQL suivante:

SELECT DATE(`date`), COUNT(customer_id) FROM tracker 
WHERE DATE(`date`) >= '2010-05-01' AND DATE(`date`) <= '2010-05-05' 
GROUP BY DATE(`date`) ORDER BY DATE(`date`); 

Et obtenez le jeu de résultats attendu:

+----+---------------------+-------------+ 
| id | date    | customer_id | 
+----+---------------------+-------------+ 
| 1 | 2010-05-10 00:00:00 |   1 | 
+----+---------------------+-------------+ 

Cependant, je voudrais que le jeu de résultats à ressembler à ceci:

+--------------+--------------------+ 
| DATE(`date`) | COUNT(customer_id) | 
+--------------+--------------------+ 
| 2010-05-01 |     0 | 
| 2010-05-02 |     0 | 
| 2010-05-03 |     1 | 
| 2010-05-04 |     0 | 
| 2010-05-05 |     0 | 
+--------------+--------------------+ 

Est-il possible de réaliser ce comportement?

+2

Il y a quelques doublons avec ce même thème, par exemple http://stackoverflow.com/questions/400759/sql-group-by-date-but-get-dates-wo-rec ords-too – Unreason

Répondre

3

Vous pouvez construire une table temporaire des dates valides dans la plage puis incorporer dans votre requête - qui est à peu près la seule voie à suivre que je peux voir immédiatement ...

Martin

1

Comme Martin dit, la meilleure solution est de créer une table temporaire avec des dates.

Ensuite, il y a 2 approches:

  • faire une jointure externe avec cette table temporaire et faire un group by sur le résultat, OU

  • group by sur la table originale + UNION select date,0 as count from date_table d where not exists (select 1 from customer c where c.date=d.date)