結合クエリ結合クエリとは、2 つ以上のテーブル間のマッチング クエリを指し、一般的には水平操作と呼ばれ、最終結果にはこれらのテーブルのすべての列が含まれることを意味します。MySQL には、クロス結合、内部結合、外部結合の 3 種類の結合操作があります。 クロス結合は CROSS JOIN と呼ばれます。2 つのテーブルで直積を実行し、2 つのテーブルのすべての列の構成を返します。たとえば、左のテーブルに n 個のレコードがあり、右のテーブルに m 個のレコードがある場合、最終結果は n*m 個のレコードになります。ただし、次のステートメントのように、それ自体と結合して最終結果を n*n 個のレコードにすることもできます。 order から * を a として選択し、orders を b としてクロス結合します。 +---------+--------+---------+--------+ | 注文ID | ユーザーID | 注文ID | ユーザーID | +---------+--------+---------+--------+ | 10007 | 2 | 10001 | 1 | | 10006 | 4 | 10001 | 1 | ..... | 10002 | 1 | 10007 | 2 | | 10001 | 1 | 10007 | 2 | +---------+--------+---------+--------+ セット内の行数は 49 行です (0.01 秒) orders テーブルには 7 つのレコードがあるため、最終的には 49 のレコードが生成されます。別の書き方は次のとおりです。 mysql> select * from orders as a ,orders as b; 結果は同じですが、書き方が異なります。上記の書き方は、1989年にアメリカ規格協会が作成したSQLの標準規格で、ANSI SQL 89規格と呼ばれていますが、最初の書き方が規定されたのは1992年です。 クロス結合の 1 つの用途は、次のステートメントのように重複データをすばやく生成することです。 注文を挿入します。a.orderId、a.userId を注文から注文として a 、注文として b として制限 10 として選択します。 以下は内部結合で、2つの部分に分かれています。まず、直積を生成し、次にフィルター条件ONに従ってフィルター処理します。2つのテーブルに同じレコードがある値を生成します。 ON の後の等号演算子 (=) に加えて、より大きい (>)、より小さい (<)、等しくない (<>) などの他の演算子を使用して接続条件を形成することもできます。 最後はOUTER JOINで、これはいくつかのフィルタリング条件に従ってテーブル間のデータを一致させることができます。INNER JOINとは異なり、OUTER JOINによって追加された予約テーブルには一致しないデータがあります。MySQLはLEFT OUTER JOINとRIGHT OUTER JOINをサポートしており、書き込み時にOUTERを省略することができます。 以下は、LEFT JOIN を示す図です。LEFT JOIN は、左側のテーブル (table1) のすべてのレコードと、右側のテーブル (table2) の一致するレコードを返します。 以下は、RIGHT JOIN を示す図です。RIGHT JOIN は、右側のテーブル (table2) のすべてのレコードと、左側のテーブル (table1) の一致するレコードを返します。 集合演算MySQL には UNION 演算子があり、2 つ以上の SELECT 結果セットを結合し、SELECT ステートメント間の重複行を削除するために使用されます。これを使用する場合は、次の基本ルールに従う必要があります。
次の表があるとします テーブルt1を作成します( id INT 主キー ); テーブルt2を作成します( id INT 主キー ); t1に値(1)、(2)、(3)を挿入します。 t2に値(2),(3),(4)を挿入します。 次のSQLを実行します t1からidを選択 連合 t2からidを選択します。 最終結果はこれです。 +----+ |id| +----+ | 1 | | 2 | | 3 | | 4 | +----+ セット内の 4 行 (0.00 秒) デフォルトでは、UNION ステートメントは結果セットから重複データを削除しますが、UNION ALL を使用して重複レコードを取得できます。 t1からidを選択 ユニオンオール t2からidを選択します。 結果は以下のとおりです +----+ |id| +----+ | 1 | | 2 | | 3 | | 2 | | 3 | | 4 | +----+ セット内の 6 行 (0.00 秒) UNION と JOIN の基本的な違いは、UNION は結果セットを水平に結合するのに対し、JOIN ステートメントは結果セットを垂直に結合することです。 要約するこれで、MySQL 接続とコレクションに関するこの記事は終了です。MySQL 接続とコレクションに関するより関連性の高い記事については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: JavaScriptは双方向リンクリストプロセス分析を実装します
目次1. LAN内のプロキシ2. イントラネットの浸透イントラネット侵入とは何ですか?橋プロキシサー...
ザビックス2019/10/12 チェンシン参照するhttps://www.zabbix.com/do...
目次成し遂げる:要約:言うことはあまりありませんが、まずは効果を見てみましょう。 カードホバー、レス...
目次MySQLを初期化するMySQL サービスをインストール + MySQL サービスを開始MySQ...
序文:以前の記事では、特定のパラメータの機能についてよく紹介してきました。しかし、MySQL パラメ...
ウェブサイトがワイドスクリーンの場合、ブラウザ ウィンドウを左右にドラッグすると、ウェブサイトの幅が...
01. コマンドの概要貼り付けコマンドは各ファイルを列ごとに結合します。これは、2 つの異なるファイ...
リクエストロジックフロントエンド --> https経由でnginxをリクエストnginx -...
目次1. データベースの使用を選択2. 情報を表示する3. テーブルを作成する4. データを挿入する...
とあるサイトからレンタルした仮想マシンの有効期限が近づいており、更新料が200元以上かかります。Al...
key_lenの意味MySQL では、次に示すように、explain を使用して SQL ステートメ...
最近、プロジェクトの開発時に MySql データベースを使用しました。MySql に関する記事をいく...
目次ソリューション分析スライス履歴書のダウンロード具体的な解決プロセス論理的分析フロントエンドサーバ...
目次charとvarcharの違いcharとvarcharの違い上記は、MySQL における cha...
目次JavaScript プロトタイプチェーンオブジェクトプロトタイプトップレベルのプロトタイプOb...