Ian*_*ber 4 mysql sql group-by date datetime-generation
我有一个查询,它将表中的所有条目分组,并按日期时间列对它们进行分组.这一切都很有效:
SELECT SUM( `value` ) AS `sum` , DATE(`datetime`) AS `dt``
FROM `entry`
WHERE entryid = 85
AND DATETIME BETWEEN '2010-01-01' AND '2010-03-01'
GROUP BY `dt`
ORDER BY `datetime`
Run Code Online (Sandbox Code Playgroud)
问题是,我需要它返回一行,即使没有找到任何东西,值设置为0.我假设有一些MYSQL函数将处理这个但似乎无法找到它.
谢谢!
MySQL没有递归功能,所以你不得不使用NUMBERS表技巧 -
创建一个只保存递增数字的表 - 使用auto_increment很容易做到:
DROP TABLE IF EXISTS `example`.`numbers`;
CREATE TABLE `example`.`numbers` (
`id` int(10) unsigned NOT NULL auto_increment,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
Run Code Online (Sandbox Code Playgroud)使用以下方法填充表:
INSERT INTO NUMBERS
(id)
VALUES
(NULL)
Run Code Online (Sandbox Code Playgroud)
......根据需要提供尽可能多的价值观.
使用DATE_ADD构建日期列表,根据NUMBERS.id值增加日期.将"2010-01-01"和"2010-03-01"替换为您的相应开始日期和结束日期(但使用相同的格式,YYYY-MM-DD) -
SELECT x.*
FROM (SELECT DATE_ADD('2010-01-01', INTERVAL n.id - 1 DAY)
FROM numbers n
WHERE DATE_ADD('2010-01-01', INTERVAL n.id -1 DAY) <= '2010-03-01' ) x
Run Code Online (Sandbox Code Playgroud)LEFT根据日期时间部分加入到您的数据表中:
SELECT DATE(x.dt) AS dt,
COALESCE(SUM(e.value), 0) AS sum_value
FROM (SELECT DATE_ADD('2010-01-01', INTERVAL n.id - 1 DAY) AS dt
FROM numbers n
WHERE DATE_ADD('2010-01-01', INTERVAL n.id -1 DAY) <= '2010-03-01' ) x
LEFT JOIN ENTRY e ON DATE(e.datetime) = x.dt
AND e.entryid = 85
GROUP BY DATE(x.dt)
Run Code Online (Sandbox Code Playgroud)简单 - 可以根据数字生成日期,就像我提供的示例一样.它还意味着使用单个表,而不是每个数据类型一个.
| 归档时间: |
|
| 查看次数: |
3507 次 |
| 最近记录: |