首页 > 解决方案 > 在 SQL Server 中显示选定的日期范围

问题描述

我有一个报告工具,我需要以以下格式显示输出,

如果我选择开始日期时间为 2019-01-10 00:00:00,结束日期时间为 2019-05-20 00:00:00,

输出应如下所示,

在此处输入图像描述

以下是我尝试过的查询,但我只得到开始日期范围或结束日期范围,但如果我们在过滤器中选择多个月份,我需要显示完整的月份日期范围

DECLARE @StartDate DateTIme
DECLARE @EndDate DateTime

SET @StartDate='2018-01-26 01:10:00'
SET @EndDate='2018-02-27 02:31:00'

;WITH GETMONTHPART(MonthNumber1,MonthNames1,StartDate,EndDate,StartDateMonth,EndDateMonth,DayRange)
AS
(

SELECT DATEPART(MM,@StartDate) MONTHNUMBER,DATENAME(MONTH,@StartDate) MONTH,@StartDate,@EndDate,CONVERT(VARCHAR(25),
DATEADD(dd,-(DAY(@StartDate)-1),@StartDate),101),
CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(DATEADD(mm,1,@EndDate))),DATEADD(mm,1,@EndDate)),101),
CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(@StartDate)-1),@StartDate),101)+' - '+CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(DATEADD(mm,1,@StartDate))),DATEADD(mm,1,@StartDate)),101) [TotalDaysofMonth]
)
,

--SELECT * FROM GETMONTHPART

CALLSUMMARY (Monthnumber,Monthname,callednumbercount) AS
(
SELECT DATEPART(MM,ccd.startdatetime) MONTHNUMBER,
DATENAME(MONTH,ccd.startdatetime) MONTH,
COUNT(callednumber) FROM table ccd WHERE startdatetime>=@StartDate and startdatetime<@EndDate
GROUP BY DATEPART(MM,ccd.startdatetime),
DATENAME(MONTH,ccd.startdatetime)
)

Select MonthName,DayRange,callednumbercount from CALLSUMMARY, GETMONTHPART

ORDER BY Monthnumber,Monthname ASC

这是目前我得到的输出,因为 DateRange 转换只对@StartDateTime 进行,所以一月份的月份范围也在二月份。如果我们将其修改为 @EndDateTime,则两个 DateRange 都将在 2 月到来。

希望这能澄清我的问题。

在此处输入图像描述

标签: sql-servercommon-table-expressiondynamic-sqldate-range

解决方案


我认为问题在于第一个 CTE 中的分组。你可以尝试这样的事情:

DECLARE @StartDate DateTIme
DECLARE @EndDate DateTime

SET @StartDate='2018-01-26 01:10:00'
SET @EndDate='2018-05-27 02:31:00'

;with a as(
          select chatID
                 ,convert(date,c.datetmStart) dateChat 
          from factChat c 
          WHERE c.datetmStart >=@StartDate 
                and c.datetmStart < @EndDate
         )

  select CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(dateChat)-1),dateChat),101) startDateMonth
        ,CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(DATEADD(mm,1,dateChat))),DATEADD(mm,1,dateChat)),101) EndDateMonth
        ,CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(dateChat)-1),dateChat),101)+' - '+CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(DATEADD(mm,1,dateChat))),DATEADD(mm,1,dateChat)),101) [DayRange]
        ,month(dateChat) monthNr
        ,count(chatID) totalChats
  from a
  group by CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(dateChat)-1),dateChat),101)
          ,CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(DATEADD(mm,1,dateChat))),DATEADD(mm,1,dateChat)),101) 
          ,CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(dateChat)-1),dateChat),101)+' - '+CONVERT(VARCHAR(25),DATEADD(dd,-(DAY(DATEADD(mm,1,dateChat))),DATEADD(mm,1,dateChat)),101) 
          ,month(dateChat)
  order by month(dateChat)

我使用了我的内部表格 factChat,但我想你会明白的。

运行查询后,我得到以下结果:

在此处输入图像描述


推荐阅读