ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
実行計画とは
SQL は宣言型の言語で、どのインデックスを使い、どんな順序で結合するかはオプティマイザが決めます。実行計画はその選択結果を可視化したものです。「インデックスが効いているか」「想定通りの結合順序か」「フルスキャンしていないか」を確認する基本ツールです。
MySQL の場合
-- 基本
EXPLAIN
SELECT * FROM users WHERE email = 'a@example.com';
-- JSON 形式(より詳細)
EXPLAIN FORMAT=JSON
SELECT * FROM users WHERE email = 'a@example.com';
-- 実測値つき(MySQL 8.0+ / 実際にクエリも走る)
EXPLAIN ANALYZE
SELECT u.name, COUNT(o.id)
FROM users u LEFT JOIN orders o ON o.user_id = u.id
GROUP BY u.id;
MySQL の EXPLAIN で特に重要な列:
| 列 | 意味 | 注目ポイント |
|---|---|---|
type | アクセス方式 | ALL(全表走査)/ index / range / ref / eq_ref / const。左ほど遅い、右ほど速い |
key | 実際に使われたインデックス | NULL ならインデックス未使用 |
rows | 調べると推定される行数 | 大きいほど遅い。実テーブル全行 ≒ Full Scan |
Extra | 追加情報 | Using filesort(ソート発生)/ Using temporary(一時表)/ Using index(カバリング) |
PostgreSQL の場合
-- 計画のみ(クエリは実行しない)
EXPLAIN
SELECT * FROM users WHERE email = 'a@example.com';
-- 実際に走らせて実測値も出す(最重要)
EXPLAIN (ANALYZE, BUFFERS, VERBOSE)
SELECT u.name, COUNT(o.id)
FROM users u LEFT JOIN orders o ON o.user_id = u.id
WHERE u.created_at >= now() - interval '30 days'
GROUP BY u.id;
PostgreSQL の代表的なノード:
| ノード | 意味 |
|---|---|
| Seq Scan | 全表走査。小さい表ならむしろ最適 |
| Index Scan | インデックス経由でテーブル参照 |
| Index Only Scan | インデックスだけで完結(高速) |
| Bitmap Heap/Index Scan | 中間規模ヒットで使われる |
| Hash Join / Merge Join / Nested Loop | 結合方式。データ量に応じてオプティマイザが選ぶ |
Oracle の場合
-- 計画を内部表に保存
EXPLAIN PLAN FOR
SELECT * FROM emp WHERE deptno = 10;
-- きれいに表示
SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY);
-- 直近実行した SQL の実プランを取る
SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY_CURSOR(NULL, NULL, 'ALLSTATS LAST'));
Oracle の出力にはアクセスパス(TABLE ACCESS FULL / TABLE ACCESS BY INDEX ROWID / INDEX UNIQUE SCAN など)と Cost / Cardinality が並びます。Cost が極端に大きい行・Full Scan の行がチューニング対象です。
SQL Server の場合
-- 計画のみ(テキスト)
SET SHOWPLAN_TEXT ON;
GO
SELECT * FROM Users WHERE Email = 'a@example.com';
GO
SET SHOWPLAN_TEXT OFF;
-- 実行 + 実プラン(Management Studio では Ctrl+M)
SET STATISTICS PROFILE ON;
SELECT ...
SET STATISTICS PROFILE OFF;
読み方の基本
- 下から上、内側から外側に読む(PostgreSQL / Oracle のツリー表示)
- 推定行数(rows / Cardinality)と実測の差が大きい行は統計情報が古いサイン
- type=ALL / Seq Scan / TABLE ACCESS FULL が大表で出ていたらインデックス追加候補
- Using filesort / Sort ノードが重ければ ORDER BY のキー / インデックスを再検討
- 結合順序が想定と違うときはヒント句や統計収集を検討
典型的な改善パターン
| 症状 | 対処 |
|---|---|
| WHERE のカラムでフルスキャン | そのカラムにインデックスを追加 |
関数 WHERE date(col)=... でインデックス無効 | 範囲条件に書き換え、もしくは関数インデックス |
| SELECT * で大きいカラムまで読む | 必要列のみに絞り、カバリングインデックスで完結 |
| 結合順序が悪い | 統計情報を最新化、駆動表を小さいほうに |
| 推定行数が実測と乖離 | MySQL: ANALYZE TABLE / Oracle: DBMS_STATS |
関連
- パフォーマンスチューニング — 親カテゴリ
- インデックス — B-Tree / 複合 / カバリング
- 統計情報 — オプティマイザの判断材料
- クエリオプティマイザ — 実行計画を決める仕組み
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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アノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?