基本上,我有一个成员资格日期和状态变化表,我想创建一个滚动计数的每一个成员数量的状态为每个日期一样:
我想输出如下:
不太确定构造这个查询的最佳方法,我想我必须创建一个递归查询来计算该日期的事件,然后透视输出来为成员状态创建单独的列?
短暂性脑缺血发作
create table MyTable(status int,st datetime, memberID int)
insert into MyTable values(1,'2022-02-01',1),
(1,'2022-03-01' ,2),
(2,'2022-04-01',1)
select [st],[1],[2]
from (select [st],memberID,status from MyTable) as SrcTable
pivot(
count(memberID) for status in ([1],[2])
) as pivottable
order by [st] asc
但是它并没有像我希望的那样在三月份聚集起来
1条答案
按热度按时间bqjvbblv1#
我把最后一个日期设置为get_date(),因为这是我在现实生活中遇到的问题所需要的,但我确实使用了递归CTE和透视