微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用上月 YYYYMM 的 SQL Server 日期计算

如何解决使用上月 YYYYMM 的 SQL Server 日期计算

我正在使用 Microsoft sql Server Management Studio 并且我正在尝试执行以下操作:我想进行计算以查找过去 2 个月和“当前”月份。

月份和年份的定义如下:

SELECT
    ID,dc.Year * 100 + dc.MonthOfYear AS YYYMM,dc.Year * 100 + dc.MonthOfYear - 1 AS PrevMonth,COUNT(1) AS Count_sales,SUM(sales) AS TotalSales
FROM
    xx (NOLOCK) dc
GROUP BY
    dc.Year * 100 + dc.[Month Of Year] 

我有 202101 时会出现问题,因为上个月被视为 202102,请问您知道年份变化时如何处理吗?

我尝试使用以下内容,但在 sql Server 中,add_months 函数不存在:

Hive SQL Integer YYYYMM previous Months

请问有什么建议吗?

解决方法

它不会是最漂亮的代码,但您可以在这里使用案例:

select 
    ID,dc.Year*100+dc.MonthOfYear as YYYMM,case when dc.MonthOfYear = 1 then dc.Year-1 else dc.Year end * 100 + dc.MonthOfYear - (case when dc.MonthOfYear = 1 then -11 else 1 end) as PrevMonth,dc.MonthOfYear-case when dc.MonthOfYear = 1 then -11 else 1 end as PrevMonthXX,count(1) as Count_sales,sum(sales) as TotalSales
from xx (nolock) dc
group by dc.Year*100+dc.[Month Of Year] 

通常更容易保存为常规日期,然后如果以后需要单独取出年和月。但有时你只是凑合着你所拥有的..

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。