
Oracle初心者です。
以下のような2種類のSQLをSQLPLUSで実行し、
実行計画を取得しました。
end_timeでfilterをかける際に、"TABLE ACCESS FULL"となっており、貼っているインデックスが使われていないことがわかりました。
#これがSQLの遅い主要因と考えています。。。。勘です。
インデックスが活用されていない原因としてはどのようなものが考えられるのでしょうか。
宜しくお願いいたします。
1)
set autotrace traceonly
select * from t_sample
where end_time >= '2009-08-25'
and end_time <= '2009-11-26'
2)
set autotrace traceonly
select * from t_sample
where end_time >= to_date('2009-08-25', 'yyyy-mm-dd')
and end_time <= to_date('2009-11-26', 'yyyy-mm-dd')
No.2ベストアンサー
- 回答日時:
テーブルの中身を知らないので何ともいえませんが
インデックスの基礎知識として選択の結果が15%以下でないと
使用する意味がないとされています。
ということで単純にSQLを実行した結果の選択行数がおおいから
フルスキャンの方が早いと判断されただけではないでしょうかね?
is nullで索引が効かなくなるといわれているのもこれと同じ理由です。
遅いというのならば索引の付け方が間違えているとかかなぁ?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
キャッシュを使わずにSELECTを...
-
WHERE句の実行順序
-
WHERE句はJOIN結合前結合後どち...
-
Oracleで検索すると、フリーズ...
-
Accessのマクロでモジュールを...
-
ODBCリンクの際にACCESSでは読...
-
callで順に実行されるプロシー...
-
重複するIDのデータを1行にま...
-
日数算出SQL
-
Statement ignored というエラー
-
SQLで部分的にGROUP BYしたいとき
-
sqlplusでヘッダーが付かない
-
sqlplusのspoolで空白行出現
-
ACCESS マクロをモジュールに変...
-
PL/SQLでSPOOLさせたいのですが...
-
PL/SQL 実行中のSID
-
Accessの数値から時間に変換す...
-
SQLserver算術オーバーフロ...
-
日付を表示形式で戻すSQL文を書...
-
今日の日付が入った行のデータ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
キャッシュを使わずにSELECTを...
-
WHERE句の実行順序
-
likeとsubstrの使いわけについて
-
ヒント句が無効になります
-
あいまい検索のパフォーマンス...
-
Like文の速度について教えてく...
-
WHERE句はJOIN結合前結合後どち...
-
いつもお世話になってます。
-
パフォーマンスについて
-
問題解決のストーリーにて PDCA...
-
SQL ORDER BYにおける条件について
-
実行計画HASH JOIN RIGHT OUTER
-
計画力をつけるにはどうすれば...
-
表の結合(性能)
-
JOINの時のONとWHEREの違いにつ...
-
アナライズでほとんどの処理が...
-
実行計画の取得方法について
-
実行計画(EXPLAIN PLAN、AUTOT...
-
外部結合と等価結合のパフォー...
-
アナライズとヒント句
おすすめ情報