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?
bir sonuca
group by
VEYAgroup 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