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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【お題】絵本のタイトル
- ・【大喜利】世界最古のコンビニについて知ってる事を教えてください【投稿~10/10(木)】
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・ハマっている「お菓子」を教えて!
- ・最近、いつ泣きましたか?
- ・夏が終わったと感じる瞬間って、どんな時?
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
キャッシュを使わずにSELECTを...
-
WHERE句の実行順序
-
問題解決のストーリーにて PDCA...
-
likeとsubstrの使いわけについて
-
実行計画HASH JOIN RIGHT OUTER
-
ヒント句が無効になります
-
ORACLE9i→11gにバージョンアッ...
-
エクセルVBAでUserFormを起動し...
-
Access VBAで行ラベルが定義さ...
-
Accessのマクロでモジュールを...
-
VBA プロシージャの名前の取得
-
全角空白のTRIMができない...
-
Statement ignored というエラー
-
14桁の日付(YYYYMMDDHHMMSS)を...
-
フォームモジュール イベント...
-
SELECT結果の縦と横の入れ替え
-
PL/SQLカーソルの2重FORループ...
-
SQL/Loaderでの年月日時分秒の...
-
Excelグラフの日付軸の日付がず...
-
SQL*Plusの終了はquit?exit?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
キャッシュを使わずにSELECTを...
-
WHERE句の実行順序
-
likeとsubstrの使いわけについて
-
ヒント句が無効になります
-
Like文の速度について教えてく...
-
問題解決のストーリーにて PDCA...
-
SQL ORDER BYにおける条件について
-
PDCAを回すって?
-
実行計画HASH JOIN RIGHT OUTER
-
【チューニング】インデックス...
-
データ抽出の速度について
-
あいまい検索のパフォーマンス...
-
アナライズでほとんどの処理が...
-
Analyzeとは?
-
外部結合と等価結合のパフォー...
-
ORACLE9i→11gにバージョンアッ...
-
計画段階での怠惰
-
WHERE句はJOIN結合前結合後どち...
-
Oracleで検索すると、フリーズ...
-
PL SQL のループ
おすすめ情報