首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从sql server表中查找周日期、月日期的总计

从sql server表中查找周日期、月日期的总计
EN

Stack Overflow用户
提问于 2019-09-23 14:45:50
回答 2查看 59关注 0票数 0

我正在设法使今天(星期一)到(上星期一),星期二到上周,星期二,等等的申请总数。此外,我想得到这个月(到目前为止)的申请。请帮帮忙

我正在使用Server 2008 R2

代码语言:javascript
复制
Category    Date    Day     Applications
CASS    16/09/2019  Monday  1
CASS    16/09/2019  Monday  3
RBS     16/09/2019  Monday  1
RBS     16/09/2019  Monday  3
RBS     16/09/2019  Monday  14
RBS     16/09/2019  Monday  15
CASS    23/09/2019  Monday  2
CASS    23/09/2019  Monday  1
CASS    23/09/2019  Monday  2
CASS    23/09/2019  Monday  1
CASS    23/09/2019  Monday  8
RBS     23/09/2019  Monday  3
RBS     23/09/2019  Monday  3

输出:

代码语言:javascript
复制
               23/09/2019

前一周14 : 14-4=10

苏格兰皇家银行:前一周6: 6-33= -27

月份(截止日期止总支出):57

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-09-23 15:08:13

使用LEAD()函数可以实现所需的功能,请参见下面的示例,您可能希望根据需要调整PARTITION BY子句和子查询:

查询结果..

代码语言:javascript
复制
SELECT  T.*, 
        LEAD (AppCount) OVER (PARTITION BY cDay ORDER BY weekNum) as PrevAppCount,
        T.AppCount - LEAD (AppCount) OVER (PARTITION BY cDay ORDER BY weekNum) 
FROM    (
        select  Category, 
                datepart(week,cDate) as weekNum,
                cDay,
                sum (AppCount) as AppCount
        from MyTable
        Group by Category, Datepart(week,cDate),cDay
        ) AS T
票数 0
EN

Stack Overflow用户

发布于 2019-09-23 16:13:26

您可以这样编写查询:

代码语言:javascript
复制
;with cte as (
select *, rown = ROW_NUMBER() over(partition by category order by [Date]) from (
    select category, [Date], sum(applications) appcnt from #table 
        group by category, [Date]
    ) t
)
Select  case when nextweek.Category is null then curweek.Category else 
 curweek.Category + ' Previous week' end , 
    case when nextweek.Category is not null then nextweek.appcnt - curweek.appcnt   else curweek.appcnt end
    from cte curweek 
  left join cte nextweek on curweek.rown = nextweek.rown -1
    and curweek.Category = nextweek.Category
union all
  select 'Month to date', sum(applications) from #table

代码:

https://rextester.com/ABI84558

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

https://stackoverflow.com/questions/58064949

复制
相关文章

相似问题

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