遅いSQLを特定する

 http://www.atmarkit.co.jp/fdb/rensai/orasql04/orasql04_1.html

  • チューニング対象SQL
    • 1実行当たりの実行時間が長いSQL
    • ディスク読み取りブロック数が多いSQL
    • バッファの読み取り数が極端に多いSQL
    • 実行回数が極端に多いSQL
  • 対象SQLの洗い出し
    • 動的パフォーマンスビューを使用したSQLの洗い出し
       [デメリット]
        ・1回当たりの実行時間などは平均値しか取得できない
        ・メモリ上にキャッシュされているSQLの情報しか確認できない
ビュー名主な格納情報主な列名列値の意味
V$SQL・SQLの先頭1000bytes
・SQLの累積リソース使用状況
SQL_TEXTSQLの先頭1000bytes
SORTSSORTの回数
FETCHESFETCHの回数
EXECUTIONS実行回数
USERS_EXECUTING現在実行中のユーザー数
PARSE_CALLS解析コールの回数
DISK_READSディスク読み込み数
BUFFER_GETSバッファ読み込み数
ROWS_PROCESSEDSQLが戻す行数
CPU_TIME処理に使用したCPU時間(マイクロ秒)
ELAPSED_TIME処理に使用した経過時間(マイクロ秒)
ADDRESSほかのViewとの結合に使用
HASH_VALUEほかのViewとの結合に使用
V$SQL_TEXT・SQLの全文SQL_TEXT64bytes単位で分割されたSQL
PIECE分割されたSQLの断片番号
ADDRESSほかのViewとの結合に使用
HASH_VALUEほかのViewとの結合に使用
V$SQL_PLAN・SQLの実行計画OBJECT_NAME実行計画中の表、索引名
OPERATION実行計画オペレーション
OPTIONS実行計画オペレーションのオプション
OPTIMIZERオプティマイザのモード
DEPTH実行計画のTreeの深さ
ADDRESSほかのViewとの結合に使用
HASH_VALUEほかのViewとの結合に使用

 

-- 合計実行時間の長いSQL
SET LINES 140
COL sql_text            FORM A140
COL buffer_per_run      FORM 999999999999
COL disk_per_run        FORM 999999999999
COL cpu_time            FORM 999999999999
COL elapsed_time        FORM 999999999999
SELECT * FROM
(SELECT
        sql_text,address,hash_value,parse_calls,executions,
        buffer_gets,disk_reads,
        buffer_gets/executions buffer_per_run,
        disk_reads/executions disk_per_run,cpu_time,
        elapsed_time
FROM v$sql
WHERE executions>0
ORDER BY elapsed_time desc)   -- この条件を変更する
WHERE rownum <= 10;           -- 表示件数はこの値を変更する

1回の実行当たりの秒数 = ELAPSED_TIME / EXECUTIONS となる
-- バッファ読み込みブロック数が多いSQL
-- ※大量のバッファ読み込みを行っているSQLは、適切でない索引や、
--  連結索引の一部を使用している可能性がある。

先のSQLのORDER BY に buffer_gets を指定する
-- ディスク読み込みブロック数が多いSQL
-- ※ディスク読み込みが多発している場合、効率の悪い索引を使用している、
--  もしくは全表スキャンを行っている可能性が考えられます。
--  ディスクI/Oは、メモリI/Oと比べて大幅に処理速度が劣るため、
--  チューニングによりディスクI/Oを減らすことができないか検討します。

先のSQLのORDER BY に disk_reads を指定する
-- 実行回数の多いSQL

先のSQLのORDER BY に executions を指定する
-- SQL全文の取得方法
-- 初めに、V$SQLからADDRESS列、HASH_VALUE列の値を確認し、下記のSQLを実行

set pages 100 feed off timing off echo off lines 140
SELECT sql_text
  FROM v$sqltext
 WHERE hash_value=V$SQLから取得したHASH_VALUE値
   AND address='V$SQLから取得したADDRESS値'
 ORDER BY piece;

トップ   差分 バックアップ リロード   一覧 単語検索 最終更新   ヘルプ   最終更新のRSS
Last-modified: 2009-06-11 (木) 00:48:52 (4244d)