簡體   English   中英

使用表值 Function 和 OR 語句對內部聯接進行索引

[英]Indexing on Inner Join with Table Valued Function and OR statement

我正在內部加入一個大表,其中一個表值 function 返回一個要加入的值。 不幸的是,我的所有索引都被繞過,導致對大表進行表掃描。 我這里只是用了 1020 作為參數,但實際上這是一個變量。

select t1.*
from [DS_DataAccess_XA_EMIR_TSR] t1 (nolock)
INNER JOIN SFTR_fn_UserAccess_GetLEIAccess(1020) t2
ON t1.[Trade Party 1 - Execution Agent ID] =  t2.LEI
OR t1.[Trade Party 2 - Execution Agent ID] = t2.LEI

我在兩個貿易方字段設置上都有單獨的索引。 function 本身即刻運行。 我也嘗試過使用交叉應用,但結果相同。 請參閱下面的執行計划,顯示大表的表掃描查詢成本:

在此處輸入圖像描述

預先感謝! 掃羅

您只需要第一個表中的數據。 所以,我建議使用exists而不是join

select t1.*
from [DS_DataAccess_XA_EMIR_TSR] t1
where exists (select 1
              from SFTR_fn_UserAccess_GetLEIAccess(1020) t2
              where t1.[Trade Party 1 - Execution Agent ID] =  t2.LEI
             ) or
      exists (select 1
              from SFTR_fn_UserAccess_GetLEIAccess(1020) t2
              where t1.[Trade Party 2 - Execution Agent ID] = t2.LEI
             );

OR 阻止引擎使用索引,因此我建議您將其拆分為兩個不同的選擇,然后合並它們。 因此,每個 select 都可以使用其對應的索引運行。

select t1.*
from [DS_DataAccess_XA_EMIR_TSR] t1 (nolock)
INNER JOIN SFTR_fn_UserAccess_GetLEIAccess(1020) t2 
           ON t1.[Trade Party 1 - Execution Agent ID] =  t2.LEI
UNION    
select t1.*
from [DS_DataAccess_XA_EMIR_TSR] t1 (nolock)
INNER JOIN SFTR_fn_UserAccess_GetLEIAccess(1020) t2 
           ON t1.[Trade Party 2 - Execution Agent ID] = t2.LEI

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM