sql-server - 在 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 月到来。
希望这能澄清我的问题。
解决方案
我认为问题在于第一个 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,但我想你会明白的。
运行查询后,我得到以下结果:
推荐阅读
- python - 按字符串列表对字典列表进行排序
- reactjs - Rollup 和 typescript 包没有编辑器代码完成并跳转到声明
- amazon-web-services - 在资源声明之外将环境变量附加到 Lambda
- firefox - 使用 policy.json 设置 Firefox 首选项
- r - 用 R + ggplot 在折线图中画一个点
- javascript - 无法取消选中所有复选框
- css - 如何使用 vuetify 和 Vue.delete() 使用效果淡出警报
- ms-access - 文本框中的表达式未将值传递给表
- c# - 查找和替换作业中的值
- chef-infra - 当重试次数大于 0 且 ignore_failure 为真时,是否会重复执行 ruby_block?