SQL - 左加入return 最新记录

SQL - Left Join return latest record

我当前的代码是:

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”,代码会返回一个结果。 但是,如果对 table 中的任何列进行任何修改,它将为该记录创建一个重复行。原始记录的结束日期为修改日期,而新记录的结束日期为“3000-12-31”。

然后我的代码将只带回活动记录。如果记录不再有效,它将有一个结束日期,例如“2018-10-15”等等 returns ? ? ? ?来自 T4 的值。

我如何修改代码以取回具有最新结束日期的记录?

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

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

这将为您提供每个 "key" 的最新行(基于您的列 eff_end_dt)。