我需要计算协议属于财政年度的一半。
如果是在七月到十二月之间,那就是H1。 如果是1月到6月,那就是H2
作为一个说明,协议可以持续多年,所以我使用AgreementEndDate今天关闭来确定财政年度。代码的这部分工作(即min(case when AgreementEndDate>=@dtDate then AgreementEndDate else '' end) as 'Agreement End Date'
)
但是,这是我遇到问题的地方。我需要在“协议窗口”的末尾添加H1或H2,但还没有想出来。
我尝试添加多个WHEN子句,但是,我得到重复的行。这就是为什么我一起去。
有什么建议?
DECLARE @dtDate DATE
SET @dtDate = GETDATE();
Select
AD.TPID
,min(case when AgreementEffectiveDate<=@dtDate then AgreementEffectiveDate else '' end) as 'Agreement Effective Date'
,min(case when AgreementEndDate>=@dtDate then AgreementEndDate else '' end) as 'Agreement End Date'
,min(case when AgreementEndDate>=@dtDate then 'FY' + convert(varchar(2),(FORMAT(AgreementEndDate, 'yy') - 1)) + ' H2'
--WHEN (month(AgreementEndDate) >= 1 and month(AgreementEndDate) <= 6) THEN 'FY' + convert(varchar(2),(FORMAT(AgreementEndDate, 'yy') - 1)) + ' H2'
--WHEN (month(AgreementEndDate) >= 7 and month(AgreementEndDate) <= 12) THEN 'FY' + convert(varchar(2),(FORMAT(AgreementEndDate, 'yy') - 1)) + ' H1'
else '' end) as 'Agreement Window'
from AgreementDetails AD
我想通了......这是解决方案。
,min(case when AgreementEndDate>=@dtDate and ((month(AgreementEndDate) >= 1 and month(AgreementEndDate) <= 6)) THEN 'FY' + convert(varchar(2),(FORMAT(AgreementEndDate, 'yy') - 1)) + ' H2'
when AgreementEndDate>=@dtDate and ((month(AgreementEndDate) >= 7 and month(AgreementEndDate) <= 12)) THEN 'FY' + convert(varchar(2),(FORMAT(AgreementEndDate, 'yy') - 1)) + ' H1'
else '' end) as 'Agreement Window'