Sto usando SQL SERVER 2008 R2
Mi sono appena imbattuto in APPLY in SQL e mi è piaciuto come risolve i problemi di query in così tanti casi,
Molti dei tavoli che stavo usando 2 join sinistro per ottenere il risultato, sono stato in grado di ottenere 1 applicazione esterna.
Ho una piccola quantità di dati nelle mie tabelle DB locali e dopo l'implementazione il codice dovrebbe essere eseguito su dati almeno 20 volte più grandi.
Temo che l'applicazione esterna potrebbe richiedere più tempo rispetto alle 2 condizioni di join a sinistra per una grande quantità di dati,
Qualcuno può dire come funziona esattamente l'applicazione e come influenzerà le prestazioni in dati molto grandi, se possibile alcune relazioni proporzionali con le dimensioni di ogni tabella come proporzionale a n1 ^ 1 o n1 ^ 2 ... dove n1 è il numero di righe nella tabella 1.
Ecco la query con 2 join a sinistra
select EC.*,DPD.* from Table1 eC left join
(
select member_id,parent_gid,child_gid,LOB,group_gid,MAX(table2_sid) mdsid from Table2
group by member_id,parent_gid,child_gid,LOB,group_gid
) DPD2 on DPD2.parent_gid = Ec.parent_gid
AND DPD2.child_gid = EC.child_gid
AND DPD2.member_id = EC.member_id
AND DPD2.LOB = EC.default_lob
AND DPD2.group_gid = EC.group_gid
left join
Table2 dpd on dpd.parent_gid = dpd2.parent_gid
and dpd.child_gid = dpd2.child_gid
and dpd.member_id = dpd2.member_id
and dpd.group_gid = dpd2.group_gid
and dpd.LOB = dpd2.LOB
and dpd.table2_sid = dpd2.mdsid
Ecco la query con applicazione esterna
select * from Table1 ec
OUTER APPLY (
select top 1 grace_begin_date,retroactive_begin_date,Isretroactive
from Table2 DPD
where DPD.parent_gid = Ec.parent_gid
AND DPD.child_gid = EC.child_gid
AND DPD.member_id = EC.member_id
AND DPD.LOB = EC.default_lob
AND DPD.group_gid = EC.group_gid
order by DPD.table2_sid desc
) DPD