sql – 按日期分组,即使没有找到记录也返回行
发布时间:2021-04-03 07:14:42 所属栏目:MsSql教程 来源:网络整理
导读:我有一个查询,它将表中的所有条目分组,并按日期时间列对它们进行分组.这一切都很有效: 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
我有一个查询,它将表中的所有条目分组,并按日期时间列对它们进行分组.这一切都很有效: 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) ……根据您的需要提供多种价值观. 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) 为什么是数字,而不是日期? 简单 – 可以根据数字生成日期,就像我提供的示例一样.它还意味着使用单个表,而不是每个数据类型一个. (编辑:广州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- sql – 如何在一行中选择多列的AVG
- sql-server – COALESCE与ISNULL的性能差异?
- 我们发现SQL Server2008R2站长网 aspzz.cn和SQL Server2012
- sql-server-2005 – 从SQL Server 2008降级到2005
- AWS携手教育部 助力中国云计算创新大计
- Maxtor总代花落讯宜——三年质保,讯宜独家!
- 泄漏的Windows Server 2003 VLK版update被锁定
- 要选就选最好的——三星光存储国庆导购指南
- Sql Server中怎样通过父记录查找出全部关联的子记录
- entity-framework-4 – 如何使用SQL Compact 4首先使用Enti
站长推荐
热点阅读