ORACLE UPDATE CORRELATED QUERY

时间:2012-08-22 07:46:23

标签: oracle

我有一个更新查询,如下所示,它使用相关方法。这需要太长时间才能运行。 有没有更好的方法来重写这个。提前感谢您的帮助。

UPDATE DAC A
   SET (acc_obj_header,
        acc_sub_header,
        acc_desc_header
   ) = (SELECT B.acc_obj,
               B.acc_sub,
               B.acc_desc
          FROM DAC B
         WHERE B.country_code = A.country_code
           AND B.comp_no = A.comp_no
           AND B.bu_no = A.bu_no
           AND B.acc_level_of_detail < A.acc_level_of_detail
           AND (B.acc_obj || B.acc_sub) = (SELECT MAX(C.acc_obj || C.acc_sub)
                                             FROM DAC C
                                            WHERE C.country_code = A.country_code
                                              AND C.comp_no = A.comp_no
                                              AND C.bu_no         =A.bu_no
                                              AND (C.acc_obj || C.acc_sub) <= (A.acc_obj || A.acc_sub)
                                              AND C.acc_level_of_detail < A.acc_level_of_detail
                                          )
           AND rownum < 2
       )

1 个答案:

答案 0 :(得分:1)

当我面对像这样的长期工作更新时,我将其重写为MERGE语句。因此,如果查询本身快速工作只需重写合并,则考虑重写查询。

我希望你(b.acc_obj || b.acc_sub)有一个FBI(基于函数的索引) - 它可以稍微提高性能。