2010-05-10 29 views
5

GROUP BY deyimiyle SELECT deyim oluşturmaya çalışıyorum, "varsayılan değerler" döndürmelidir.SQL GROUP BY "varsayılan değerler" ile

Aşağıdaki basit MySQL tablo düşünün:

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

tablo yalnızca bir kayıt içerir:

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`); 

: Aşağıdaki SQL sorgusu yürütme ediyorum koğuşları sonra

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

Ve beklenen sonuç kümesini alın:

+--------------+--------------------+ 
| 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 | 
+--------------+--------------------+ 

bu davranış elde etmek mümkün mü:

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

Ancak, bu gibi görünecek şekilde ayarlanırsa sonuç istersiniz?

+2

bir sonuca group by VEYA

  • group by yapıyor musunuz Aynı temaya sahip birkaç kopya var. Örneğin, http://stackoverflow.com/questions/400759/sql-group-by-date-but-get-dates-wo-rec ords'ün-de – Unreason

  • cevap

    3

    Sen aralığında geçerli tarihlerin geçici bir tablo oluşturmak ve sonra da sorguya içine dahil olabilir - ileri ben hemen görebilirsiniz tek yolu hakkında ... Martin gibi

    Martin

    1

    En iyi çözüm, tarihlerle tempolu bir tablo oluşturmak olduğunu söyledi.

    Sonra 2 yaklaşım var:

    • bir dış ki sıcaklık tabloyla katılmak ve orijinal tablodan + UNION select date,0 as count from date_table d where not exists (select 1 from customer c where c.date=d.date)