あるテーブルから別のテーブルに編集をマージするためのSQLステートメントがあります。つまり
UPDATE f
SET f.AUDAPLCDE = m.AUDAPLCDE, f.AUDSTF_NO = m.AUDSTF_NO,
f.AUDUPD_ID = m.AUDUPD_ID, f.AUDUPDDTE = m.AUDUPDDTE,
f.UNTTYP = m.UNTTYP, f.UNTSTM_NO = m.UNTSTM_NO,
f.UNTIND = f.UNTIND, f.UNQ = m.UNQ,
f.TRNCTL_NO = m.TRNCTL_NO, f.TRN_NO = m.TRN_NO,
f.STAEVT = m.STAEVT, f.SPSDTE = m.SPSDTE,
f.RVRRSN = m.RVRRSN, f.AUDUPDTME = m.AUDUPDTME,
f.RHTTYP = m.RHTTYP, f.ALCADJ = m.ALCADJ,
f.RESFAC = m.RESFAC, f.PRTDTE = m.PRTDTE,
f.POLREF = m.POLREF, f.OUTFAC = m.OUTFAC,
f.OTHBENQTY = m.OTHBENQTY, f.ORIIND = m.ORIIND,
f.ORIDTE = m.ORIDTE, f.INRTYP = m.INRTYP,
f.INRREF = m.INRREF, f.FNDTRNTYP = m.FNDTRNTYP,
f.FNDSUBTYP = m.FNDSUBTYP, f.FNDREF = m.FNDREF,
f.FNDPRC = m.FNDPRC, f.EVTUNQ = m.EVTUNQ,
f.EVTTRN_NO = m.EVTTRN_NO, f.EFVDTE = m.EFVDTE,
f.DUEDTE = m.DUEDTE, f.CTBPCT = m.CTBPCT,
f.CO_REF = m.CO_REF, f.CAL_YR = m.CAL_YR,
f.BONSUBTYP = f.BONSUBTYP, f.BONSTA = m.BONSTA,
f.BONDCL_YR = m.BONDCL_YR, f.BON_YR = m.BON_YR,
f.BENTYP = m.BENTYP, f.BENREF = m.BENREF,
f.BENQTY2 = m.BENQTY2, f.BENQTY1 = m.BENQTY1,
f.AMT = m.AMT, f.ALCRTE = m.ALCRTE
FROM FI700 f
INNER JOIN MERGEDATA_FI700 m ON m.FI700_UNIQUE_ID = f.FI700_UNIQUE_ID
AND m.SSIS_UPDATE_TYPE = 'U'
AND m.SSIS_TIMESTAMP in (SELECT max(mm.SSIS_TIMESTAMP)
FROM MERGEDATA_FI700 mm
WHERE mm.FI700_UNIQUE_ID = m.FI700_UNIQUE_ID
AND mm.SSIS_UPDATE_TYPE = 'U')
実際、私は最新の編集(TimeStampによる)フィールドを取得しようとしています。これには、すべての累積編集が含まれるためです。これにより、パフォーマンスを向上させることができると確信しています。つまり、SELECT max(mm.SSIS_TIMESTAMP)
ネストされたクエリをその上の結合に統合することができます。
何かご意見は?