
No.2ベストアンサー
- 回答日時:
ビューの基表に、有効活用できるインデクスがあれば、インデクスは活用されます。
>例えば元のテーブルに「hoge_id(index)」があり、
>VIEWテーブルが「vtable」だとします。
>SELECT * FROM vtable WHERE hoge_id = 値
>または、
>SELECT * FROM vtable LEFT JOIN atable ON vatble.hoge_id = atable.id
>(atable.idもindex)
>などとした場合、hoge_idのindexが有効で高速に結果が返ってくるということでよろしいのでしょうか。
表の母体データ件数が相当に少ない(例えば、数百件など)とか、重複キー値が多量に存在するといった場合は、RDBMSのオプティマイザが、「インデクスを使うより、テーブルスキャン(表のデータを全件サーチ)した方が速い」と判断し、インデクスを利用しない場合もあります。
主キーなどユニークなキーでの「=」条件や範囲条件などで、母体データからある程度絞り込んだ検索をするなら、インデクスの活用で母体データが大量に増えても、一定の性能を出せます。
No.1
- 回答日時:
有効です。
VIEWにはINDEXは作れませんし。SaKaKashi 様、ご回答ありがとうございます。
有効なんですね。
安心しました。
えと、、
ちょっと自分の質問が説明不足だったせいで少し不安なので再確認させて頂きたいのですが、
例えば元のテーブルに「hoge_id(index)」があり、
VIEWテーブルが「vtable」だとします。
SELECT * FROM vtable WHERE hoge_id = 値
または、
SELECT * FROM vtable LEFT JOIN atable ON vatble.hoge_id = atable.id
(atable.idもindex)
などとした場合、hoge_idのindexが有効で高速に結果が返ってくるということでよろしいのでしょうか。
最初から上記のように質問すればよかったですね。。すみません。
どうぞよろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
select文のwhere句に配列を入れ...
-
エクセルで最後の文字だけ置き...
-
マイクラPC版のコマンドで効率...
-
入力値と外部キーをINSERTするには
-
ある条件の最大値+1を初番する...
-
MySQLのint型で001と表示する方...
-
URL と行番号の指定
-
”photo id” とは何ぞや?
-
sqlで、600行あるテーブルを100...
-
レコード削除・sqlインジェクシ...
-
SQLサーバから、項目の属性(型...
-
テーブル作成時のカラムについて
-
所有格の意味
-
スクリーンセイバー
-
Yahoo .comの idには年齢制限、...
-
VBA リボンのCheckBox2個をOpt...
-
PL/SQLの変数について
-
差し込み後、元データを変更し...
-
1日に1人がこなせるプログラム...
-
access2003 クエリSQL文に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
エラー 1068 (42000): 複数の主...
-
エクセルの関数について教えて...
-
VIEWの元のテーブルのindexって...
-
sqlで、600行あるテーブルを100...
-
SQLサーバから、項目の属性(型...
-
SQL Left Join で重複を排除す...
-
Access パラメータクエリをcsv...
-
クエリ表示と、ADOで抽出したレ...
-
ストアドのエラーについて
-
マイクラPC版のコマンドで効率...
-
バインド変数について
-
SQLにて特定の文字を除いた検索...
-
副問合せの書き方について
-
【Transact-sql】 execの結果を...
-
”photo id” とは何ぞや?
-
mysql+phpをつかったカートつく...
-
MySQL5.5 viewの処理速度改善に...
-
select文のwhere句に配列を入れ...
-
テーブル名を省略して「h.id」...
おすすめ情報