2009-09-08 4 views
0

У меня есть инструкция SQL для объединения изменений из одной таблицы в другую. То естьМожно ли сделать это заявление 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) ....

Любые мысли?

ответ

2

Две маленьких вещей - не уверены, что, если они делают большую разницу, хотя:

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') 

1) Есть ли индекс SSIS_TIMESTAMP, который может быть использован ??

2) Поскольку вы выбираете значение MAX, вы могли бы использовать знак равенства вместо оператора «IN»:

AND m.SSIS_TIMESTAMP = (SELECT max(mm.SSIS_TIMESTAMP) 

Марк

+0

На самом деле, нет никакого индекса на отметку времени. Я добавил его в поле ID и в поле UPDATE_TYPE. Спасибо за комментарий '='. –

+0

Увидев ваш запрос SELECT max(), вы можете создать индекс на (FI700_UNIQUE_ID, SSIS_UPDATE_TYPE, SSIS_TIMESTAMP), так как вы используете все три поля в своем выборе. –

+0

@marc_s: Путь впереди вас, но спасибо в любом случае :) –

Смежные вопросы