ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
本稿は SQL のインラインビューに関する記事です。インラインビューは Oracle 用語として広まっていますが、現在ではほぼすべての RDBMS で同じ概念がサポートされています。
インラインビューとは?
インラインビュー (Inline View) とは、FROM 句に書く SELECT 文 (副問い合わせ) のことです。あらかじめ作成しておく永続的なビュー (CREATE VIEW) ではなく、その SQL の中でその場限りに使い捨てる仮想テーブルとして動作します。
|
SELECT u.name, t.cnt |
インラインビューを使う典型的なケース
| ユースケース | 例 |
|---|---|
| 集計してから結合 | ユーザ別注文件数を計算 → users と JOIN |
| 絞り込み済みの「小さなテーブル」を用意 | 過去 30 日の対象データのみで JOIN し性能改善 |
| 同じ複雑なサブクエリを別名で扱う | FROM (...) AS top10 として読みやすく |
| ウィンドウ関数の結果を外側で参照 | SELECT * FROM (SELECT ..., ROW_NUMBER() OVER (...) rn FROM t) WHERE rn = 1 |
| UNION を1つの集合として扱う | FROM (SELECT ... UNION ALL SELECT ...) AS x |
類似機能との違い
| 機能 | 定義位置 | 寿命 | 備考 |
|---|---|---|---|
| インラインビュー | FROM句内のサブクエリ | そのクエリのみ | その場限り。命名は別名 (AS x) |
| CTE (WITH句) | クエリ先頭の WITH name AS (...) | そのクエリのみ | 名前付きでクエリ内で複数回参照可 |
| ビュー (VIEW) | CREATE VIEW | 永続 | スキーマに登録される |
| マテリアライズドビュー | CREATE MATERIALIZED VIEW | 永続+実体化 | 結果を物理保存。Oracle / PostgreSQL 等で利用 |
| 一時テーブル | CREATE TEMPORARY TABLE | セッション内 | 明示的にデータを保持 |
| スカラサブクエリ | SELECT 句や WHERE 句 | その場限り | 結果は 1 行 1 列のみ |
CTE (WITH句) との書き換え例
同じ処理はインラインビューでも CTE でも書けます。複雑になるほど CTE のほうが見やすいことが多いです。
|
-- CTE 版 |
パフォーマンス上のポイント
- インラインビュー内で不要な列を取らない。
SELECT *は避けて必要列のみ - WHERE で先に絞ると、外側の JOIN が高速になる
- 同じ集計を外側で何度も呼ぶような書き方ならCTE / 一時テーブルを検討
EXPLAINで実行計画を確認し、フルスキャンになっていないかチェック- Oracle の場合、インラインビューに
WITH ... ASヒントや マテリアライズドビューが効くケースがある
注意点
- 多くの RDBMS でインラインビューには必ず別名 (
AS xやx) を付ける必要がある - インラインビュー内で
ORDER BYは省略可能。最終結果の並びは外側のORDER BYで決める - ネストが深くなりすぎると可読性が落ちる。3階層以上は CTE への書き換えを検討
- RDBMS により対応 SQL 機能が異なる (ウィンドウ関数の対応バージョン等)。サポート状況を確認
関連
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?