使用sql查询选择最近30天

MrM*_*MrM 6 sql sql-server sql-server-2008

我在寻找过去30天内周一,周二,周三,周四,周五,周六,周日的数量.我可以在没有实际数据库表的情况下选择最近30天的日期和星期几吗?就像是

SELECT --everything between
convert(date,GETDATE()), DATENAME(DW, GETDATE())
--and
convert(date,GETDATE() - 30), DATENAME(DW, GETDATE())
Run Code Online (Sandbox Code Playgroud)

Lam*_*mak 12

您可以使用递归CTE:

;WITH CTE AS
(
    SELECT convert(date,GETDATE()) sDate, DATENAME(DW, GETDATE()) sDayofWeek
    UNION ALL
    SELECT DATEADD(DAY,-1,sDate), DATENAME(DW, DATEADD(DAY,-1,sDate))
    FROM CTE
    WHERE sDate > GETDATE()-29
)
SELECT * FROM CTE
Run Code Online (Sandbox Code Playgroud)