結合クエリ結合クエリとは、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 つのドメイン名で複数のプロジェクトにアクセスする方法...
目次単一ノード差分単一要素を調整するマルチノード差分調整子配列ノードが移動したかどうかを判断するには...
目次動作原理:ブラウザは何をするのですか?ホストファイル index.htmlメイン.jsその他のベ...
luaをインストールする http://luajit.org/download/LuaJIT-2.0...
CocosCreator バージョン: 2.3.4 Cocos には List コンポーネントがない...
<br />Web デザインと制作テスト パート I 多肢選択問題 1. 単一選択問題 ...
目次背景制限の最適化最適化方法1. カバーインデックスを使用する2. サブクエリの最適化3. 遅延連...
この記事では、Dockerでイメージ情報を表示する方法を学ぶ必要があります。 1. imagesコマ...
概要この記事は、ゲームビジネスアーキテクチャに関連するコンテンツの紹介から始まります。ゲームビジネス...
1. 建設1. htpasswd.txtファイルを準備するファイルには、パッケージを倉庫にアップロー...
React Native は、現在人気のオープンソース JavaScript ライブラリ React...
1. はじめに最近ブログをアップグレードし、記事ページの下部に前の記事と次の記事に直接ジャンプできる...
目次1. テーブルを作成する1.1. テーブルを作成するための基本構文1.1.1. シンプルなテーブ...
サーバーデータがSSL証明書を使用して暗号化および認証されていない場合、ユーザーのデータはプレーンテ...
DOMContentLoaded イベント文字通り、DOM がロードされた後に実行されます。 win...