大家好,我正在研究某种会计系统,并遇到一些困难。这个问题已经由Abdul Rasheed在这个网站上回答了。如何获得SQL Server中两个日期之间的开始日期和结束日期
这是代码
declare @sDate datetime,
@eDate datetime
select @sDate = '2013-02-21',
@eDate = '2013-04-25';
with CTE_TEST
as (
select @sDate SDATE,
DATEADD(s, - 1, DATEADD(mm, DATEDIFF(m, 0, @sDate) + 1, 0)) EDATE
union all
select EDATE + 1,
DATEADD(s, - 1, DATEADD(mm, DATEDIFF(m, 0, DATEADD(MONTH, 1, SDATE)) + 1, 0))
from CTE_TEST C
where DATEADD(MONTH, 1, SDATE) < DATEADD(s, - 1, DATEADD(mm, DATEDIFF(m, 0, @eDate) + 1, 0))
)
select DATENAME(MONTH, SDATE) MNAME,
SDATE, (case when EDATE > @eDate then @eDate else EDATE end) EDATE
from CTE_TEST
代码的伟大工程,就像我想要什么。但我想将结果插入到新表中。我怎么做?
什么是您的预期输出..? – Mansoor
来自@Abdul Rasheed的代码 –
请确保标题符合您的实际问题 – HoneyBadger