加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

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

发布时间:2021-04-03 08:51:01 所属栏目:编程 来源:网络整理
导读:我有一个查询,它将表中的全部条目分组,并按日期时刻列对它们举办分组.这统统都很有用: SELECT SUM( `value` ) AS `sum`,DATE(`datetime`) AS `dt``FROM `entry` WHERE entryid = 85AND DATETIME BETWEEN '2010-01-01' AND '2010-03-01'GROUP BY `dt`ORDER BY

我有一个查询,它将表中的全部条目分组,并按日期时刻列对它们举办分组.这统统都很有用:

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`

题目是,我必要它返回一行,纵然没有找到任何对象,将值配置为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;

>行使以下要领添补表格:

INSERT INTO NUMBERS
  (id)
VALUES
  (NULL)

……按照您的必要提供多种代价观.
>行使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

>按照日期时刻部门LEFT JOIN到您的数据表:

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)

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

简朴 – 可以按照数字天生日期,就像我提供的示例一样.它还意味着行使单个表,而不是每个数据范例一个.

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读