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で質問しましょう!
似たような質問が見つかりました
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- JavaScript Typescript が必要な理由 1 2023/01/07 11:45
- Excel(エクセル) エクセルのマクロの有効について 4 2023/08/03 11:40
- MySQL 【MySQL】本当に困っているので、助けてください。よろしくお願いします。 3 2023/06/03 14:24
- MySQL [1000地域 × 10カテゴリー = 1万件のテーブル]!グループ化? 1 2023/06/14 23:56
- MySQL 【投稿情報用データベース posts】は必要ないと思います。 1 2022/06/02 21:25
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- MySQL 何にかが違うから エラーなんでしょうね! 2 2022/09/18 05:28
- Excel(エクセル) INDEX関数とMATCH関数を使用し値を返す数式についてです 2 2022/04/20 13:40
- 車検・修理・メンテナンス 自動車 シリコーン灯油の防錆効果というのはすごいのでしょうか アンダーコートより良い? 2 2023/03/28 20:35
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教える店舗&オフィスのセキュリティ対策術
中・小規模の店舗やオフィスのセキュリティセキュリティ対策について、プロにどう対策すべきか 何を注意すべきかを教えていただきました!
-
Viewにインデックスは張れますか?
Oracle
-
VIEWに対してWHERE句をつける
MySQL
-
ビューにインデックスを設定できませんか?
SQL Server
-
-
4
列番号による項目の取得について
SQL Server
-
5
ビューで引数を使いたい
SQL Server
-
6
MySQLで数字の値のもののみを取り出す
MySQL
-
7
データベースのINT型項目にNULLはNG?
MySQL
-
8
SQLServerで文字列の末尾からある位置で取出
SQL Server
-
9
可変個数のデータはどう納める?
その他(データベース)
-
10
レコードの登録順がおかしい
MySQL
-
11
テーブルの最後(最新)のレコードを抽出したい
MySQL
-
12
SELECT文で、指定カラム以外の全カラムを一括指定って可能でしょうか
MySQL
-
13
SELECT INTOで一度に複数の変数へ代入をするにはどのようにすれがよいでしょうか?
PostgreSQL
-
14
データベース関係で、データの洗い替えとはどのような事を行うことでしょう
IT・エンジニアリング
-
15
IISワーカープロセスが原因でCPUが100%に
Microsoft ASP
-
16
ロックテーブルサイズ超えのエラー対処
MySQL
-
17
FTPでputすると空ファイルが出来てしまう
その他(プログラミング・Web制作)
-
18
Windowsのバッチファイルで正規表現の置換方法について…
Windows 10
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
VIEWの元のテーブルのindexって...
-
insertを高速化させたい
-
副問合せの書き方について
-
SQL Left Join で重複を排除す...
-
ある条件の最大値+1を初番する...
-
selectした大量データをinsert...
-
マイクラPC版のコマンドで効率...
-
select文のwhere句に配列を入れ...
-
一つ前のレコードの値と減算し...
-
my_itemsテーブルのIDにAUTO_IN...
-
期間の重複を調べるSQL文につい...
-
1対多結合で多を絞り込み条件と...
-
SELECT~LIKE~の結果が変
-
1テーブル&複数レコードの更新...
-
MySQLにてCOUNTした値を更にCOUNT
-
エクセルの関数について教えて...
-
Unionした最後にGROUP BYを追加...
-
SQLサーバから、項目の属性(型...
-
バインド変数について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
VIEWの元のテーブルのindexって...
-
SQLサーバから、項目の属性(型...
-
select文のwhere句に配列を入れ...
-
副問合せの書き方について
-
マイクラPC版のコマンドで効率...
-
Unionした最後にGROUP BYを追加...
-
selectした大量データをinsert...
-
SQLにて特定の文字を除いた検索...
-
[SQLServer] テーブル名からカ...
-
1テーブル&複数レコードの更新...
-
inner joinをすると数がおかし...
-
クエリ表示と、ADOで抽出したレ...
-
ある条件の最大値+1を初番する...
-
sqlで、600行あるテーブルを100...
-
複数テーブルのGROUP BY の使い...
-
insertを高速化させたい
-
PL/SQLの変数について
-
キー毎の、ある列のmaxのレコー...
おすすめ情報