skillup

技術ブログ

Database

SQL結合 サブクエリに関して

投稿日:

今回はサブクエリに関してです。

もちろんSQL実践入門を読み進めています。

SQL上ではテーブル、ビュー、サブクエリというのは機能的にはそれほど変わらず主にパフォーマンスの点で違いがでてきます。

以下に簡単な特徴を述べます。

テーブル、ビュー、サブクエリの特徴

テーブル

永続的かつデータを保持する

ビュー

永続的だがデータは保持しないため、アクセスのたびにSQLが実行される

サブクエリ

非永続的なので生存期間(スコープ)がSQL文の実行中に限られる

サブクエリの問題点

ここでサブクエリの問題点を挙げておきます。

計算コストが上乗せされる

データを保持していないので、実行のたびにSELECTを実行してデータを作る必要があります。純粋にSELECT文実行にかかるコストが上乗せされます。

IOコストがかかる

計算した結果は、どこかに保持するため書き込む必要があります。うまくメモリに収まればよいですが、そうでない場合はストレージに書き込むことになり、遅延の原因になります。

最適化を受けられない

サブクエリにはインデックスが利かないため、最適化を受けることができません。

詳細はSQL実践入門の中にゆずりますが、サブクエリの中にはウィンドウ関数を使って代用できるものなどがかなり多くあります。この場合、ウィンドウ関数を使ったほうがパフォーマンスが良くなるケースがあるので積極的に利用しましょう。

-Database

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

Webの高速化に関して

Webの高速化に関してメモ。 高速化って言っても幅広いんですけどね。自分が行なっている対策に関して。 一応LAMP環境を前提にしてます。 Contents1 一番大事なのは測定2 DB対策3 フロント …

no image

SQL基礎 結合に関して

SQL実践入門を読んで勉強しておりますが、本日は結合に関して。 Contents1 クロス結合2 内部結合3 外部結合4 結合のアルゴリズムとパフォーマンス4.1 NestedLoops4.2 Has …

no image

DBの基礎 テーブルとは

CSSを学習したあとはデータベースの学習などを。 参考図書:「達人に学ぶDB設計指南書」基本的にはこれを読んでいきます。が、現状よくわからないところは飛ばしていきます・・・ Contents1 テーブ …

no image

オプティマイザと実行計画

データベースがSQLを受け取って処理を実行する前には下記のような段階があります。 Contents1 パーサー2 オプティマイザ3 カタログマネージャー4 テーブルからデータの取得5 参考リンク パー …

no image

sourceコマンドに関して(Linuxサーバー&MySQL)

Linux上ではコマンドをテキストファイルに記述して、

と入力すると命令を実行してくれます。 シェルスクリプトよりもお手軽に実行できる …