結合クエリ結合クエリとは、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) yumのkeepchche機能を有効にする: 方法1 2) yum-utils ソフト...
背景: 一部の実験はサーバー上で完了する必要があります。したがって、リモート サーバー上のコードをロ...
1. Alibaba Cloudは、個人のニーズに応じて適切なクラウドサーバーを選択し、CPU、メ...
今日はあまり使わないHTMLタグ「subタグ」と「supタグ」を紹介します。関連記事: HTML タ...
Baiduのインタビューで遭遇する質問は、次のレイアウト効果を達成する必要がある。 中央の紫色の列...
サーバーのデータベース ハード ディスク領域がいっぱいだったため、大量のデータの書き込みに失敗し、「...
1. 基本概念1. Sitemeshはページ装飾技術です。 1 : フィルターを通してページアクセス...
1. HTMLタグは常に閉じる前のページのソース コードでは、次のような記述がよく見られます。 &l...
ファイルの保存とアクセスを容易にするために、FTPサービスが特別に構築されています。 FTP サーバ...
Rational ClearCase は、コードやその他のソフトウェア開発資産のバージョン管理を実...
Unix ライクなシステムでは、コマンドまたはプロセスの実行がいつ開始されたか、またプロセスがどのく...
公式サイトからインストールパッケージをダウンロードします: mysql-8.0.19-linux-g...
具体的な方法:まずコマンドプロンプトを開きます。次に、[ mysql -u root -p ] コマ...
参考までにWindowsにMySQLをインストールします。具体的な内容は次のとおりです。 1.まずM...
日常の開発タスクでは、データ テーブル内のグループ化フィールドに基づいて統計データを取得するために、...