1

重複の可能性:
多くの CASE ステートメントを含むクエリ - 最適化

こんにちは、みんな、

非常に多くの CASE ステートメントが含まれているため、最適化できる非常に汚いクエリが 1 つあります。

SELECT (CASE pa.KplusTable_Id WHEN 1 THEN sp.sp_id 

    WHEN 2 THEN fw.fw_id
 WHEN 3 THEN s.sw_Id
 WHEN 4 THEN id.ia_id END) as Deal_Id,  
max(CASE pa.KplusTable_Id WHEN 1 THEN sp.Trans_Id 
              WHEN 2 THEN fw.Trans_Id
                WHEN 3 THEN s.Trans_Id
              WHEN 4 THEN id.Trans_Id END) as TransId_CurrentMax
INTO #MaxRazlicitOdNull
FROM #PotencijalniAktuelni pa LEFT JOIN kplus_sp sp (nolock) on sp.sp_id=pa.Deal_Id     AND pa.KplusTable_Id=1
      LEFT JOIN kplus_fw fw (nolock) on fw.fw_id=pa.Deal_Id AND pa.KplusTable_Id=2  
         LEFT JOIN dev_sw s (nolock) on s.sw_Id=pa.Deal_Id AND pa.KplusTable_Id=3
           LEFT JOIN kplus_ia id (nolock) on id.ia_id=pa.Deal_Id AND pa.KplusTable_Id=4
 WHERE isnull(CASE pa.KplusTable_Id WHEN 1 THEN sp.BROJ_TIKETA 
                       WHEN 2 THEN fw.BROJ_TIKETA
              WHEN 3 THEN s.tiket
              WHEN 4 THEN id.BROJ_TIKETA END, '')<>'' 
GROUP BY CASE pa.KplusTable_Id WHEN 1 THEN sp.sp_id 
             WHEN 2 THEN fw.fw_id
       WHEN 3 THEN s.sw_Id
       WHEN 4 THEN id.ia_id END

私は同じ条件を数回持っているので、クエリを最適化し、よりシンプルでより良いものにする方法を知っていますか. すべての提案を歓迎します!

事前にTnX!

ネマニャ

4

0 に答える 0