1

相関メソッドを使用している以下のような更新クエリがあります。実行に時間がかかりすぎています。これを書き直すより良い方法はありますか?あらかじめご了承ください。

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
       )
4

1 に答える 1

1

そのような長時間の更新に直面したとき、MERGEステートメントに書き直しました。そのため、クエリ自体が高速に動作する場合は、マージするように書き直してください。それ以外の場合は、クエリを書き直すことを検討してください。

(b.acc_obj || b.acc_sub) に FBI (関数ベースのインデックス) があることを願っています。パフォーマンスがわずかに向上する可能性があります。

于 2012-08-22T07:57:10.500 に答える