ホームページ データベース SQL SQLの実行順序は何ですか?

SQLの実行順序は何ですか?

Jun 10, 2019 am 10:36 AM

SQLの実行順序は何ですか?

#SQL ステートメントの実行シーケンス

MySQL ステートメントは、次の図に示すように、合計 11 のステップに分かれています。最初に FROM 操作が常に実行され、LIMIT 操作が最後に実行されます。各操作では、処理の入力として使用される仮想テーブルが生成されますが、これらの仮想テーブルはユーザーには透過的ですが、結果として返されるのは最後の仮想テーブルのみです。ステートメントに句が指定されていない場合、対応するステップはスキップされます。

# クエリ処理の各段階を詳しく分析しましょう

FORM: 左側のテーブルと右側のテーブルについてFROM Table のデカルト積を計算します。仮想テーブル VT1

ON の生成: 仮想テーブル VT1 に対して ON フィルタリングを実行し、 を満たす行のみが仮想テーブル VT2 に記録されます。

JOIN: OUTER JOIN (左結合、右結合など) が指定されている場合、保持表内の一致しない行が仮想表 VT2 に外部行として追加され、仮想表 VT3 が作成されます。 from sub- 文に 3 つ以上のテーブルが含まれている場合は、すべてのテーブルが処理されるまで、前の結合接続によって生成された結果 VT3 と次のテーブルに対してステップ 1 ~ 3 が繰り返されます

WHERE: WHERE 条件を実行します仮想テーブル VT3 でのフィルタリング。 を満たすレコードのみが仮想テーブル VT4 に挿入されます。

GROUP BY: group by 句の列に従って VT4 のレコードをグループ化し、VT5 を生成します。

CUBE | ROLLUP: テーブル VT5 に対してキューブまたはロールアップ操作を実行して、テーブル VT6 を生成します。

HAVING: 仮想テーブル VT6 に Having フィルターを適用します。 を満たすレコードのみが仮想テーブル VT7 に挿入されます。

SELECT: 選択操作を実行し、指定された列を選択して、仮想テーブル VT8 に挿入します。

DISTINCT: VT8 でレコードの重複を除去します。仮想テーブル VT9 を生成します。

ORDER BY: 仮想テーブル VT9 内のレコードを に従ってソートし、仮想テーブル VT10 を生成します。

LIMIT: 指定された行のレコードを取り出し、仮想テーブル VT11 を生成し、結果を返します。

書き込み順序

: select... from... where.... group by... getting... order by... limit [offset,] (行数)

実行順序

: from... where...group by... getting.... select... order by...limit

以上がSQLの実行順序は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

SQL DateTimeの使用方法 SQL DateTimeの使用方法 Apr 09, 2025 pm 06:09 PM

DateTimeデータ型は、0001-01-01-01 00:00:00:00:00:00:00:00:00:00:00:00:59:59.999999999:59:59.99999999の範囲の高精度の日付情報を保存するために使用され、内部はdateTime(精度)です。変換機能は機能しますが、精度、範囲、およびタイムゾーンを変換する際に潜在的な問題に注意する必要があります。

SQLステートメントを使用してSQL Serverでテーブルを作成する方法 SQLステートメントを使用してSQL Serverでテーブルを作成する方法 Apr 09, 2025 pm 03:48 PM

SQL ServerでSQLステートメントを使用してテーブルを作成する方法:SQL Server Management Studioを開き、データベースサーバーに接続します。データベースを選択してテーブルを作成します。作成テーブルステートメントを入力して、テーブル名、列名、データ型、制約を指定します。 [実行]ボタンをクリックしてテーブルを作成します。

SQL IFステートメントの使用方法 SQL IFステートメントの使用方法 Apr 09, 2025 pm 06:12 PM

SQLステートメントは、SQLステートメントを条件付きで実行するために使用され、構文は次のようになります。if(条件)then {ステートメント} else {ステートメント} end if;。条件は有効なSQL式である可能性があり、条件が真の場合、then句を実行します。条件が偽の場合は、else句を実行します。ステートメントをネストできる場合、より複雑な条件付きチェックを可能にします。

SQLページネーションとはどういう意味ですか? SQLページネーションとはどういう意味ですか? Apr 09, 2025 pm 06:00 PM

SQL Pagingは、パフォーマンスとユーザーエクスペリエンスを改善するために、セグメントの大規模なデータセットを検索するテクノロジーです。 Limit句を使用して、スキップするレコードの数と返されるレコードの数(制限)を指定します。利点には、パフォーマンスの向上、ユーザーエクスペリエンスの向上、メモリの節約、および簡素化されたデータ処理が含まれます。

SQL最適化のためのいくつかの一般的な方法 SQL最適化のためのいくつかの一般的な方法 Apr 09, 2025 pm 04:42 PM

一般的なSQL最適化方法は次のとおりです。インデックス最適化:適切なインデックスアクセラレーションされたクエリを作成します。クエリの最適化:マルチテーブル結合の代わりに、正しいクエリタイプ、適切な結合条件、およびサブクエリを使用します。データ構造の最適化:適切なテーブル構造、フィールドタイプを選択し、ヌル値の使用を避けるようにしてください。クエリキャッシュ:クエリキャッシュを有効にして、頻繁に実行されるクエリ結果を保存します。接続プールの最適化:接続プールを使用して、マルチプレックスデータベース接続を行います。トランザクションの最適化:ネストされたトランザクションを避け、適切な分離レベルを使用し、バッチ操作を使用します。ハードウェアの最適化:ハードウェアをアップグレードし、SSDまたはNVMEストレージを使用します。データベースメンテナンス:インデックスメンテナンスタスクを定期的に実行し、統計を最適化し、未使用のオブジェクトをクリーンにします。クエリ

SQL注射を判断する方法 SQL注射を判断する方法 Apr 09, 2025 pm 04:18 PM

SQLインジェクションを判断する方法には、疑わしい入力の検出、元のSQLステートメントの表示、検出ツールの使用、データベースログの表示、および浸透テストの実行が含まれます。注入が検出された後、脆弱性のパッチを適用し、パッチを確認し、定期的に監視し、開発者の意識を向上させるための措置を講じます。

SQLでの宣言の使用 SQLでの宣言の使用 Apr 09, 2025 pm 04:45 PM

SQLの宣言ステートメントは、変数、つまり変数値を保存するプレースホルダーを宣言するために使用されます。構文は次のとおりです:declare<変数名> <データ型> [デフォルト<デフォルト値>];ここで<変数名>変数名、<データ型>そのデータ型(VarcharやIntegerなど)、および[default< default値>]はオプションの初期値です。宣言ステートメントは、中間体を保存するために使用できます

SQLステートメントを確認する方法 SQLステートメントを確認する方法 Apr 09, 2025 pm 04:36 PM

SQLステートメントを確認する方法は次のとおりです。SyntaxChecking:SQL EditorまたはIDEを使用します。論理チェック:テーブル名、列名、条件、およびデータ型を確認します。パフォーマンスチェック:説明または分析を使用してインデックスを確認し、クエリを最適化します。その他のチェック:変数、許可、およびテストクエリを確認します。

See all articles