結合クエリ結合クエリとは、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. 環境整備1.MySQLインストールパス: /usr/local 2. CentOS 6.2 ...
LinuxでのMySQL-5.7.19バージョンの初心者向けの最初のインストールについては、前の記事...
オリンピック期間中にIE8ベータ2がリリースされ、英語版のリリースに合わせて中国語版も第一波でリリー...
サービス.xml Server.xml 構成ファイルは、コンテナー全体を構成するために使用されます。...
ボックスモデルの計算<br />マージン + ボーダー + パディング + コンテンツC...
序文この記事では主にMySQLでよく使われるツールに関する関連コンテンツを紹介し、皆さんの参考と学習...
Ubuntu 20.04をインストールする NVIDIAドライバーをインストールする Pytouch...
ナビゲーション バー、固定トップ ナビゲーション バー、およびセカンダリ メニューの実装効果図の実装...
2つのケース: 1. 索引あり 2. 索引なし前提条件:方法: コマンドラインを使用してシミュレート...
この記事では、DingTalkの勤怠カレンダーを実装するためのVueの具体的なコードを参考までに共有...
目次1. 再帰とは何ですか? 2. 再帰を使って数学の問題を解く1. 1 * 2 * 3 * 4 …...
私は現在、Xiao Nian Gao に似たビデオおよびツール アプリを開発しています。ユーザーが作...
目次1. シーンの読み込み2. ノードを見つける1. ノード検索2. その他のノード操作3. 再生ア...
1: readonly は、このコントロールをロックして、インターフェイス上で変更できないようにしま...
目次スクロールをスムーズにするBetterScrollのスクロール体験慣性ローリングエッジリバウンド...