簡體   English   中英

提高Oracle中的SQL查詢性能

[英]Improve sql query performance in oracle

我現有的查詢如下所示:

SELECT p.subcode as proc_subcode,
       r.subcode as rv_subcode,
       r.rlv,
       f.cfid,
       f.geozip,
       p.proc,
       p.sh_descr,
       f.begproc,
       f.endproc,
       p.descr,
       r.modi,
       f.per25
  FROM user.code p, user.relative r, user.frequency f
 WHERE f.ID = 'XOF'
   AND f.GEOZIP = '200'
   AND f.REL_DATE = '10-SEP-13'
   AND p.proc IN ('A0021', 'A0080', 'A0090', 'A0100', 'A0110', 'A0120',
        'A0130', 'A0140', 'A0160', 'A0170', 'A0180', 'A0190',
        'A0200', 'A0210', 'A0225')
   AND r.ID = f.ID
   AND f.REL_DATE = r.REL_DATE
   AND f.ID = p.ID
   AND f.REL_DATE = p.REL_DATE
   AND p.proc = r.proc
   AND p.proc between f.begproc AND f.endproc
   AND (('A0021' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0021' AND
       r.PROC = 'A0021' AND f.CFID = '00') OR
       ('A0080' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0080' AND
       r.PROC = 'A0080' AND f.CFID = '00') OR
       ('A0090' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0090' AND
       r.PROC = 'A0090' AND f.CFID = '00') OR
       ('A0100' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0100' AND
       r.PROC = 'A0100' AND f.CFID = '00') OR
       ('A0110' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0110' AND
       r.PROC = 'A0110' AND f.CFID = '00') OR
       ('A0120' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0120' AND
       r.PROC = 'A0120' AND f.CFID = '00') OR
       ('A0130' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0130' AND
       r.PROC = 'A0130' AND f.CFID = '00') OR
       ('A0140' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0140' AND
       r.PROC = 'A0140' AND f.CFID = '00') OR
       ('A0160' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0160' AND
       r.PROC = 'A0160' AND f.CFID = '00') OR
       ('A0170' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0170' AND
       r.PROC = 'A0170' AND f.CFID = '00') OR
       ('A0180' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0180' AND
       r.PROC = 'A0180' AND f.CFID = '00') OR
       ('A0190' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0190' AND
       r.PROC = 'A0190' AND f.CFID = '00') OR
       ('A0200' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0200' AND
       r.PROC = 'A0200' AND f.CFID = '00') OR
       ('A0210' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0210' AND
       r.PROC = 'A0210' AND f.CFID = '00') OR
       ('A0225' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0225' AND
       r.PROC = 'A0225' AND f.CFID = '00'))
 ORDER BY p.proc, r.modi, f.REL_DATE asc

上面的查詢效果很好,但是,我打算在范圍內添加100個p.proc。 就像A0021-A1000。 因此,我想提高sql查詢的性能。

有人可以幫忙嗎?

編輯1:

我想可能的解決方案是刪除p.proc的IN子句,並在之間使用它們。 我不確定最后的AND條件。

編輯2:

查詢說明

我基本上是使用geozip並通過代碼來獲得特定區域的所有醫療費用,例如。 A0021表示手術代碼,200表示紐約,2013年9月10日是XOF產品的發布日期和獲取結果。

首先

 WHERE f.ID = 'XOF'
   AND f.GEOZIP = '200'
   AND f.REL_DATE = '10-SEP-13'
   AND p.proc IN ('A0021', 'A0080', 'A0090', 'A0100', 'A0110', 'A0120',
        'A0130', 'A0140', 'A0160', 'A0170', 'A0180', 'A0190',
        'A0200', 'A0210', 'A0225')
   AND r.ID = f.ID
   AND f.REL_DATE = r.REL_DATE
   AND f.ID = p.ID
   AND f.REL_DATE = p.REL_DATE
   AND p.proc = r.proc
   AND p.proc between f.begproc AND f.endproc
   AND (('A0021' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0021' AND
       r.PROC = 'A0021' AND f.CFID = '00') OR
       ('A0080' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0080' AND
       r.PROC = 'A0080' AND f.CFID = '00') OR
       ('A0090' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0090' AND
       r.PROC = 'A0090' AND f.CFID = '00') OR....

在查詢中p.proc = r.proc。 因此,您無需每次在以下語句中編寫它:

 ('A0090' BETWEEN f.BEGPROC AND f.ENDPROC AND p.PROC = 'A0090' AND
   r.PROC = 'A0090' AND f.CFID = '00') OR

在所有這些語句中,f.CFID = '00'。 您無需在每個語句中編寫它。 目前,我認為您需要的是:

WHERE f.ID = 'XOF'
       AND f.GEOZIP = '200'
       AND f.REL_DATE = '10-SEP-13'
       AND p.proc IN ('A0021', 'A0080', 'A0090', 'A0100', 'A0110', 'A0120',
            'A0130', 'A0140', 'A0160', 'A0170', 'A0180', 'A0190',
            'A0200', 'A0210', 'A0225')
       AND r.ID = f.ID
       AND f.REL_DATE = r.REL_DATE
       AND f.ID = p.ID
       AND f.REL_DATE = p.REL_DATE
       AND p.proc = r.proc
       AND p.proc between f.begproc AND f.endproc
       AND f.CFID='00'

這4條陳述

           AND p.proc IN ('A0021', 'A0080', 'A0090', 'A0100', 'A0110', 'A0120',
                'A0130', 'A0140', 'A0160', 'A0170', 'A0180', 'A0190',
                'A0200', 'A0210', 'A0225')
           AND p.proc = r.proc
           AND p.proc between f.begproc AND f.endproc
           AND f.CFID='00'

與所有這些BETWEEEN語句相同。

請檢查您的數據查詢

暫無
暫無

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

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