0

Oracle 和 SQL 对我来说是新手,我仍处于学习阶段。

你能帮我调整一下oracle查询吗?此表包含约 95 条 lac 记录,使用此查询检索数据需要 1 小时。

您的建议/意见/帮助将不胜感激。

提前致谢。

    SELECT A.CNO   AS CNO,
       A.FNO AS FNO,
       A.CID AS CID,
       A.IID             AS IID
  FROM CAC_LKP A,
       (SELECT C_DATE, CNO, FNO
          FROM (SELECT MAX(CAC_LKP.C_DATE) AS C_DATE,
                       CAC_LKP.CNO AS CNO,
                       CAC_LKP.FNO AS FNO
                  FROM CAC_LKP
                 WHERE ACTIVE = 'Y'
                 GROUP BY CNO, FNO)) B
 WHERE A.C_DATE = B.C_DATE
   AND A.CNO = B.CNO
   AND A.FNO = B.FNO
   AND A.ACTIVE = 'Y'

主键是通过 c_date、iid、active 的组合定义的。

4

2 回答 2

2

您正在使用聚合来获取变量组的最新日期。然后,您将获得与这些日期匹配的行。

要优化查询,请忘记自连接并改用分析函数:

select cno, fno, cid, lid
from (select A.*,
             rank() over (partition by cno, fno order by c_date desc) as seqnum
      from cac_lkp A
      where A.active = 'Y'
     ) A
where seqnum = 1;
于 2013-06-01T07:48:55.147 回答
0

由于数据量很大,去除不必要的子查询可以提高性能。确保您在 C_DATE、CNO、FNO 和 A.ACTIVE 上有索引。试试这个 sql

SELECT A.CNO   AS CNO,
       A.FNO AS FNO,
       A.CID AS CID,
       A.IID             AS IID
  FROM CAC_LKP A,
       (SELECT MAX(CAC_LKP.C_DATE) AS C_DATE,
                       CAC_LKP.CNO AS CNO,
                       CAC_LKP.FNO AS FNO
                  FROM CAC_LKP
                 WHERE ACTIVE = 'Y'
                 GROUP BY CNO, FNO) B
 WHERE A.C_DATE = B.C_DATE
   AND A.CNO = B.CNO
   AND A.FNO = B.FNO
   AND A.ACTIVE = 'Y'
于 2013-06-01T07:58:44.260 回答