2つのテーブルを(内部)結合させる場合、
INNER JOINによる結合と
WHERE句に結合条件を記述する2通りの方法が
あると思いますが、どちらが早いのでしょうか?
なお、Oracle9i、ルールベースにて構築されています。
テーブルの内容、SQL文は下記のとおりです。
ご教授よろしくお願いします。
■表 A
項目A-1 ・・・PRIMARY KEY1、INDEX1
項目A-2 ・・・PRIMARY KEY2、INDEX2
項目A-3 ・・・PRIMARY KEY3
項目A-4
■表 B
項目B-1 ・・・PRIMARY KEY1、INDEX1
項目B-2 ・・・PRIMARY KEY2、INDEX2
項目B-3 ・・・PRIMARY KEY3
項目B-4
※項目A-1と項目B-1にて結合。
項目A-2が"01"と等しいレコード。
表Aのレコード件数>表Bのレコード件数
【WHERE句にて結合】
SELECT * FROM A,B
where A.項目1 = B.項目1
and A.項目2 = '01'
【INNER JOINにて結合】
SELECT * FROM A
INNER JOIN A
ON A.項目1 = B.項目1
AND A.項目2 = '01'
No.3ベストアンサー
- 回答日時:
表定義の見方がよくわかりませんが、PRIMARY KEYを3つのカラムに設定している時点でインデックスは死んでしまっているような気がするのですが。
結合方法をWHERE句に記述してもINNER JOINを使用しても実行計画が変わることはないようです。
ただし、LEFT JOIN, RIGHT JOINを使用した場合は強制的にコストベースになるので注意が必要です。
また、FROM句でA, Bの順に記述されていますが、A.項目2 = '01'の条件で絞り込んでも、まだ
Aの件数 > Bの件数が成り立つのでしょうか?
もし、これで逆転するようなら、A.項目2にインデックスを作成し、FROM句をB, Aとした方が性能がよくなるように思われます。
ちなみに、ご存知かも知れませんが、ルールベースがサポートされているのは9iまでで、10gからは完全に廃止されています。
No.2
- 回答日時:
オプティマイザは、マイナーバージョンでも変更されると聞きますし、
COMPATIBLE 初期パラメータでも、変動します。
どちらが高速かは、わかりませんが。
(+)演算子の未来も暗そうなので、WHEREで結合条件を書くのは控えて
INNER JOIN で書いていった方が将来明るいと思います。
どうしても調べたいならば、TRACEすれば個別のケースでは優劣は付くかもしれませんが
それで、100%の正解にはならないと思います。
あと、#2さんの指摘に加えて、
どのようなパターンだとしても(複合でも単独でも)、インデックスが冗長のように見えます。
No.1
- 回答日時:
説明に出てくる”PRIMARY KEY1”、”PRIMARY KEY2”の意味がわかりません。
複数項目で設定したプライマリキーの第一項目、第二項目の意味でしょうか?
INDEX1,INDEX2も不明ですが..
【WHERE句にて結合】と【INNER JOINにて結合】の違いは、
従来型の記述か、ANSI構文かの違いなので、
それによる速度差は無いのではないかと思いますが、
実行計画を見ないと確かなことは言えません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- SQL Server [SQLServer] テーブル名からカラム名を取得する 1 2022/08/23 21:20
- Oracle SQL update方法 2 2022/06/22 14:07
- Visual Basic(VBA) VBAで、1つのエクセルで、2つのシートからもう1つのシートに条件のある転記コードを教えてください。 1 2023/03/16 18:07
- MySQL あと、MySQLの文字コードはutf8 気になりますね 1 2022/12/01 07:22
- Excel(エクセル) ピボットテーブルについて 列フィールドに複数横並びに項目を表示したい場合、階層毎に表示されてしまう現 2 2022/06/28 00:27
- Oracle 下記のsqlで取得されるレコード以外を取得する方法ありますでしょうか。 SELECT B.番号, B 2 2022/04/20 23:21
- その他(Microsoft Office) Excel 2列の値を返す数式についてです 1 2022/11/23 22:59
- Excel(エクセル) 列を自動で追加したい 3 2022/07/11 12:58
- システム CSVファイルのマッピング処理の省力化 1 2022/11/24 00:01
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
キャッシュを使わずにSELECTを...
-
WHERE句の実行順序
-
Like文の速度について教えてく...
-
likeとsubstrの使いわけについて
-
あいまい検索のパフォーマンス...
-
【チューニング】インデックス...
-
WHERE句はJOIN結合前結合後どち...
-
ヒント句が無効になります
-
Accessのマクロでモジュールを...
-
Statement ignored というエラー
-
sqlplusでヘッダーが付かない
-
今日の日付が入った行のデータ...
-
VBA プロシージャの名前の取得
-
エクセルVBAでUserFormを起動し...
-
Accessの数値から時間に変換す...
-
Accessでグローバル変数を宣言...
-
callで順に実行されるプロシー...
-
SQL*Plusの終了はquit?exit?
-
全角空白のTRIMができない...
-
SQLで部分的にGROUP BYしたいとき
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
キャッシュを使わずにSELECTを...
-
WHERE句の実行順序
-
likeとsubstrの使いわけについて
-
Like文の速度について教えてく...
-
WHERE句はJOIN結合前結合後どち...
-
問題解決のストーリーにて PDCA...
-
実行計画HASH JOIN RIGHT OUTER
-
ヒント句が無効になります
-
あいまい検索のパフォーマンス...
-
800万件のテーブル読み込み...
-
Oracleで検索すると、フリーズ...
-
SQL ORDER BYにおける条件について
-
JOINの時のONとWHEREの違いにつ...
-
【チューニング】インデックス...
-
アナライズとヒント句
-
DATE型カラムのインデックスが...
-
Analyzeとは?
-
外部結合と等価結合のパフォー...
-
DBの実行計画って?
-
Oracle 実行計画、統計情報の見方
おすすめ情報