【发布时间】:2012-08-23 07:22:36
【问题描述】:
在 some_table 中创建的每条“记录”都有一个“日期”。
some_table:
-------------------------
id | record | my_date
-------------------------
1 | rec_a | 2012-08-01
2 | rec_b | 2012-08-02
3 | rec_c | 2012-08-02
4 | rec_d | 2012-08-04
5 | rec_e | 2012-08-06
6 | rec_f | 2012-08-06
我的查询:
start_date 和 end_date 来自输入
SELECT
my_date, COUNT(my_date) AS _count
FROM
some_table
WHERE
my_date
BETWEEN
start_date
AND
end_date
GROUP BY
DAY (my_date)
数组:
while($result = mysql_fetch_assoc($my_query))
{
$dataset[] = array($result['my_date'],intval($result['_count']));
}
json_encode($dataset);
这将使:
["2012-08-01",1]
["2012-08-02",2]
["2012-08-04",4]
["2012-08-06",6]
什么是最好的方法来获得没有这样的计数的日子?
["2012-08-01",1]
["2012-08-02",2]
["2012-08-03",0] <--
["2012-08-04",4]
["2012-08-05",0] <--
["2012-08-06",6]
【问题讨论】:
-
这似乎和你的问题类似:stackoverflow.com/questions/75752/…
-
@themanatuf:很好地解决了。