人力検索はてな
モバイル版を表示しています。PC版はこちら
i-mobile

MYSQLの質問です。
WHERE句の順番で、抽出速度は変わるのでしょうか。

例えば次のようなSQLです。
結果は同じになるのですが、条件の順番を変えています。

(1)のほうが抽出速度が早いような気がしているのですが、
MYSQLではどうでしょう。


(1)絞り込める条件を先に
SELECT *
FROM 顧客データ
WHERE
住所="北海道" AND 性別="男"

(2)絞り込める条件を後に
SELECT *
FROM 顧客データ
WHERE
性別="男" AND 住所="東京"

●質問者: webuser
●カテゴリ:ウェブ制作
✍キーワード:MySQL SELECT SQL どうでしょう データ
○ 状態 :終了
└ 回答数 : 3/3件

▽最新の回答へ

1 ● hijk05
●1ポイント

(2)の方が、どんなデータベースでも早いです。

◎質問者からの返答

ありがとうございます。

理由を書いて頂けると助かります。


2 ● deep_one
●10ポイント

インデックスの付き方で変わってくるかもしれませんが、1の方が早いと思います。

スピードにこだわる必要があるときには、住所のカラムにインデックスが設定されていることを確かめてください。

◎質問者からの返答

ありがとうございます。


3 ● bigvan
●100ポイント ベストアンサー

結論から言いますとどちらも結果は同じです。

MySQLのクエリオプティマイザは自動的に実行前にクエリの構文解析を行い最も効率的なクエリの実行方法を見つけ出します。

・適切なインデックス候補が存在するか

・どのインデックスが最適であるか

・どのテーブルが関係するのか

・エイリアスを使用するのか

・複数テーブルの場合どの結合順序が適切か

・どの検索順序が適切か

ですから結果は同じになるのです。

◎質問者からの返答

ありがとうございます。

根拠まで書いて頂けたのでどても参考になります。

関連質問


●質問をもっと探す●



0.人力検索はてなトップ
8.このページを友達に紹介
9.このページの先頭へ
対応機種一覧
お問い合わせ
ヘルプ/お知らせ
ログイン
無料ユーザー登録
はてなトップ