SQL - Left Join返回最新记录

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

我目前的代码是:

SELECT
T1.SC,
T2.ACC,
T3.C_IDENT,
T4.TITLE,
T4.MID,
T4.SUR
FROM D_REG.AR_JOINT T1

LEFT JOIN E_BASE.ACC_TRANS T2
ON T1.SC = T2.SC
AND T1.ACC = T2.ACC
AND T2.IDENTIFEIR_END_DATE ='3000-12-31'

LEFT JOIN E_BASE.B_HOLDING T3
ON T2.M_IDENT = T3.C_IDENT
AND T3.EFF_END_DATE ='3000-12-31'
AND T3.P_HOLDING_END+DATE ='3000-12-31'

LEFT JOIN E_BASE.PNAM T4
ON T3.C_IDENT = T4.C_IDR
AND T4.EFF_END_DATE ='3000-12-31'

目前代码声明如果结束日期='3000-12-31'则返回结果。但是,如果对表中的任何列进行任何修改,它将为该记录创建一个重复行。原件的结束日期为修改日期,而新记录的结束日期为“3000-12-31”。

我的代码只会带回活动记录。如果记录不再有效,它将有一个结束日期,例如'2018-10-15',所以返回? ? ? ?来自T4的值。

如何修改代码以恢复具有最新结束日期的记录?

sql date left-join teradata record
1个回答
0
投票

对于Teradata,您可以使用Qualify来约束ODAP函数,在这种情况下使用ROW_NUMBER() ..如果不了解有关数据的更多信息,则无法完全回答您的问题。但基本上,添加到您的查询

QUALIFY ROW_NUMBER() OVER (PARTITION BY <YOUR KEY COLUMN(S) ORDER BY  T4.EFF_END_DT DESC) = 1

这将为您提供每个“密钥”的最新行(基于您的列eff_end_dt)。

© www.soinside.com 2019 - 2024. All rights reserved.