在新列中选择特定列的下一个后续更改

时间:2019-04-19 09:50:43

标签: sql sql-server sql-server-2012

我有一个表,该表具有关于居住在房屋中的客户合同的唯一索引。我想知道某人搬出房屋(合同结束日期)和开始新合同需要多长时间。为此,我想知道该房子中的下一个合同是什么,但是与(可能不同的)客户的旧合同在同一行。

表格的当前外观,我在此处选择前十名:

SELECT TOP 10
PMCCONTRACT.ACCOUNTNUM  --Customer
,PMCCONTRACT.RENTALOBJECTID --House
,PMCCONTRACT.CONTRACTID --Contract & Unique index of the table
,PMCCONTRACT.VALIDFROM  --Contract Start Date
,PMCCONTRACT.VALIDTO    --Contract End Date
FROM PMCCONTRACT

然后推出:

ACCOUNTNUM  RENTALOBJECTID  CONTRACTID  VALIDFROM               VALIDTO
101852      2488            HC000001    1994-03-01 00:00:00.000 NULL
101136      2489            HC000002    1920-01-01 00:00:00.000 NULL
101352      2491            HC000003    1996-09-16 00:00:00.000 NULL
100687      2492            HC000004    1984-11-01 00:00:00.000 NULL
105160      2499            HC000005    1975-05-02 00:00:00.000 2018-01-31 00:00:00.000
102821      2501            HC000006    1997-09-16 00:00:00.000 NULL
100731      2506            HC000007    1920-01-01 00:00:00.000 2018-11-15 00:00:00.000
102797      2508            HC000008    1998-02-01 00:00:00.000 NULL
102155      2512            HC000009    1981-09-01 00:00:00.000 NULL
102563      2515            HC000010    1965-10-17 00:00:00.000 2017-06-30 00:00:00.000

我想要的是,根据RENTALOBJECTID,它将显示那套房子的《 First Next》合约是什么(因此重要的是,CONTRACTID在此表中保持唯一)。

下面是我用来获取代码的代码,但是,它显示了该特定RENTALOBJECTID(房屋)的以下所有合同更改。

SELECT --TOP 1000
     PMCCONTRACT.CONTRACTID
    ,PMCCONTRACT.RENTALOBJECTID
    ,PMCCONTRACT.VALIDFROM
    ,PMCCONTRACT.VALIDTO
    ,P2.CONTRACTID AS 'FirstNextContractId'
    ,P2.VALIDFROM 
    ,P2.VALIDTO 
FROM PMCCONTRACT
    LEFT JOIN PMCCONTRACT P2 
        ON  PMCCONTRACT.RENTALOBJECTID = P2.RENTALOBJECTID
        LEFT JOIN 
            (SELECT 
                RENTALOBJECTID,
                MAX(CONTRACTID) AS CONTRACTID 
            FROM PMCCONTRACT  
            GROUP BY RENTALOBJECTID) X ON X.CONTRACTID = P2.CONTRACTID
WHERE P2.VALIDFROM > PMCCONTRACT.VALIDTO

这是我仅选择ContractID HC000028时得到的结果,它显示2行,而我希望它仅显示第一行。

CONTRACTID  RENTALOBJECTID  VALIDFROM               VALIDTO                 FirstNextContractId VALIDFROM2              VALIDTO2
HC000028    75              1995-01-01 00:00:00.000 2016-04-30 00:00:00.000 HC009990            2016-05-01 00:00:00.000 2018-11-25 00:00:00.000 --<< Only row I want to show
HC000028    75              1995-01-01 00:00:00.000 2016-04-30 00:00:00.000 HC025218            2018-11-26 00:00:00.000 1900-01-01 00:00:00.000 --Too far in the future

亲切的问候,

伊戈尔

1 个答案:

答案 0 :(得分:1)

看起来简单的LEAD窗口函数就足够了。返回分区和排序子句定义的下一行。

SELECT TOP 10
    PMCCONTRACT.ACCOUNTNUM  --Customer
    ,PMCCONTRACT.RENTALOBJECTID --House
    ,PMCCONTRACT.CONTRACTID --Contract & Unique index of the table
    ,PMCCONTRACT.VALIDFROM  --Contract Start Date
    ,PMCCONTRACT.VALIDTO    --Contract End Date
    ,LEAD(CONTRACTID) OVER (PARTITION BY RENTALOBJECTID ORDER BY VALIDFROM) AS NextContractID
    ,LEAD(VALIDFROM)  OVER (PARTITION BY RENTALOBJECTID ORDER BY VALIDFROM) AS NextVALIDFROM
    ,LEAD(VALIDTO)    OVER (PARTITION BY RENTALOBJECTID ORDER BY VALIDFROM) AS NextVALIDTO
FROM PMCCONTRACT
;