首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >按日期分组,按月、年分列

按日期分组,按月、年分列
EN

Stack Overflow用户
提问于 2014-06-23 02:53:28
回答 1查看 282关注 0票数 0

我这里有一个数据样品。我曾经问过这里,哪个是有效的,但是当我对它进行了更深入的测试时,我忘记了一个事实,那就是我也应该对Year进行解释。

所以简单地说,我想把记录按月范围分组。AugJan (1组),FebJuly (2组)。因为我想知道每6个月有多少学校物体被创建。一个持续的趋势是具体的。

结果集,如:

代码语言:javascript
复制
+-----------+-------+---------------+
| sc_object | count | range         |
+-----------+-------+---------------+
| pencil    | 1     | 2013-8 2014-1 |
| eraser    | 1     | 2014-2 2014-7 |
| pencil    | 1     | 2014-2 2014-7 |
| sharpener | 1     | 2014-2 2014-7 |
| pencil    | 1     | 2014-8 2015-1 |
| eraser    | 1     | 2015-2 2015-7 |
| pencil    | 1     | 2015-2 2015-7 | 
| sharpener | 1     | 2015-2 2015-7 |
| eraser    | 1     | 2015-8 2016-1 | 
| sharpener | 2     | 2016-2 2016-7 | 
| pencil    | 1     | 2016-2 2016-7 |
| sharpener | 1     | 2016-8 2017-1 |
| eraser    | 1     | 2016-8 2017-1 |
+-----------+-------+---------------+

任何帮助都将是非常感谢的。非常感谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-06-23 03:16:32

您可以这样做(http://www.sqlfiddle.com/#!3/41ac6/19):

代码语言:javascript
复制
WITH cteRanges
AS
(
    SELECT
            site,
            CASE
              WHEN MONTH(date) IN (1) THEN CAST(YEAR(date) - 1 AS VARCHAR(4)) + '-8' + ' ' + CAST(YEAR(date) AS VARCHAR(4)) + '-1'
              WHEN MONTH(date) IN (8, 9, 10, 11, 12) THEN CAST(YEAR(date) AS VARCHAR(4)) + '-8' + ' ' + CAST(YEAR(date) + 1 AS VARCHAR(4)) + '-1'
              ELSE CAST(YEAR(date) AS VARCHAR(4)) + '-2' + ' ' + CAST(YEAR(date) AS VARCHAR(4)) + '-7'
            END AS range
    FROM
            test
)

SELECT
          site,
          COUNT(*),
          range
FROM
          cteRanges
GROUP BY
          site,
          range
ORDER BY
          range,
          site;

根据月份和年份计算范围,然后汇总结果。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24357831

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档