SQL查询 - 具有不同部分的案例

问题描述 投票:0回答:1

我需要计算协议属于财政年度的一半。

如果是在七月到十二月之间,那就是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
sql
1个回答
0
投票

我想通了......这是解决方案。

,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'
© www.soinside.com 2019 - 2024. All rights reserved.