sql – 按日期分组,即使没有找到记录也返回行

前端之家收集整理的这篇文章主要介绍了sql – 按日期分组,即使没有找到记录也返回行前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个查询,它将表中的所有条目分组,并按日期时间列对它们进行分组.这一切都很有效:
  1. SELECT SUM( `value` ) AS `sum`,DATE(`datetime`) AS `dt``
  2. FROM `entry`
  3. WHERE entryid = 85
  4. AND DATETIME BETWEEN '2010-01-01' AND '2010-03-01'
  5. GROUP BY `dt`
  6. ORDER BY `datetime`

问题是,我需要它返回一行,即使没有找到任何东西,将值设置为0.我假设有一些MysqL函数会处理这个,但似乎无法找到它.

谢谢!

解决方法

MysqL没有递归功能,因此您只需使用NUMBERS表技巧 –

>创建一个只保存递增数字的表 – 使用auto_increment很容易做到:

  1. DROP TABLE IF EXISTS `example`.`numbers`;
  2. CREATE TABLE `example`.`numbers` (
  3. `id` int(10) unsigned NOT NULL auto_increment,PRIMARY KEY (`id`)
  4. ) ENGINE=InnoDB DEFAULT CHARSET=latin1;

>使用以下方法填充表格:

  1. INSERT INTO NUMBERS
  2. (id)
  3. VALUES
  4. (NULL)

……根据您的需要提供多种价值观.
>使用DATE_ADD构建日期列表,根据NUMBERS.id值增加日期.将“2010-01-01”和“2010-03-01”替换为您的相应开始日期和结束日期(但使用相同的格式,YYYY-MM-DD) –

  1. SELECT x.*
  2. FROM (SELECT DATE_ADD('2010-01-01',INTERVAL n.id - 1 DAY)
  3. FROM numbers n
  4. WHERE DATE_ADD('2010-01-01',INTERVAL n.id -1 DAY) <= '2010-03-01' ) x

>根据日期时间部分LEFT JOIN到您的数据表:

  1. SELECT DATE(x.dt) AS dt,COALESCE(SUM(e.value),0) AS sum_value
  2. FROM (SELECT DATE_ADD('2010-01-01',INTERVAL n.id - 1 DAY) AS dt
  3. FROM numbers n
  4. WHERE DATE_ADD('2010-01-01',INTERVAL n.id -1 DAY) <= '2010-03-01' ) x
  5. LEFT JOIN ENTRY e ON DATE(e.datetime) = x.dt
  6. AND e.entryid = 85
  7. GROUP BY DATE(x.dt)

为什么是数字,而不是日期?

简单 – 可以根据数字生成日期,就像我提供的示例一样.它还意味着使用单个表,而不是每个数据类型一个.

猜你在找的MsSQL相关文章