※検証にはSQLServerを使用しています。 プロダクション環境で1分ほどかかってしまうクエリを実行する機能があったため、1秒程度までチューニングしたときのお話です。 該当のSQLは、20個ほどのテーブルをJOINして結果をSELECTする複雑なSQLでした。 クエリの中にはサブクエリのJOINも含まれており、調査の結果このサブクエリがボトルネックになっているようでした。 実行プランをみると、IndexScanの実際の行数が2億オーバーです。該当テーブルは本当は50万レコードくらいしかないので、最初はバグかな?と思いました。 統計情報は更新されているし、option(recompile)をつけて実行しても同じ実行プランで実行されてしまいます。 --問題のSQL概要(ざっくりしててすみません。。) SELECT いろんなカラム FROM いろんなテーブル -- ↓ ここがボトルネック JO