MySQL 接続とコレクションの簡単な分析

MySQL 接続とコレクションの簡単な分析

結合クエリ

結合クエリとは、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 ステートメント間の重複行を削除するために使用されます。これを使用する場合は、次の基本ルールに従う必要があります。

  • すべての 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 をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL サブクエリ (ネストされたクエリ)、結合テーブル、複合クエリの詳細な説明
  • MySQL の高度なクエリとコレクションによるグループ化の紹介

<<:  JavaScriptは双方向リンクリストプロセス分析を実装します

>>:  HTML の rel 属性の分析

推薦する

Nginx 1つのドメイン名で複数のプロジェクトにアクセスする方法の例

背景最近、複数のプロジェクトを展開する際に、1 つのドメイン名で複数のプロジェクトにアクセスする方法...

React diffアルゴリズムソースコード分析

目次単一ノード差分単一要素を調整するマルチノード差分調整子配列ノードが移動したかどうかを判断するには...

この記事では、Viteがブラウザのリクエストに対して何を行うかを説明します。

目次動作原理:ブラウザは何をするのですか?ホストファイル index.htmlメイン.jsその他のベ...

NginxにLuaモジュールを追加する方法

luaをインストールする http://luajit.org/download/LuaJIT-2.0...

CocosCreatorでリストを作成する方法

CocosCreator バージョン: 2.3.4 Cocos には List コンポーネントがない...

Webデザインと制作のテスト問題と参考回答

<br />Web デザインと制作テスト パート I 多肢選択問題 1. 単一選択問題 ...

MySQL 最適化チュートリアル: 大規模なページングクエリ

目次背景制限の最適化最適化方法1. カバーインデックスを使用する2. サブクエリの最適化3. 遅延連...

Dockerでイメージ情報を表示する方法

この記事では、Dockerでイメージ情報を表示する方法を学ぶ必要があります。 1. imagesコマ...

CocosCreatorメッセージ配信メカニズムの詳細な説明

概要この記事は、ゲームビジネスアーキテクチャに関連するコンテンツの紹介から始まります。ゲームビジネス...

Docker を使用して pypi プライベート リポジトリを構築する方法

1. 建設1. htpasswd.txtファイルを準備するファイルには、パッケージを倉庫にアップロー...

React Nativeがシミュレータにリンクできない件について

React Native は、現在人気のオープンソース JavaScript ライブラリ React...

Mysql は非集計列を選択できません

1. はじめに最近ブログをアップグレードし、記事ページの下部に前の記事と次の記事に直接ジャンプできる...

MYSQLテーブルの包括的な概要

目次1. テーブルを作成する1.1. テーブルを作成するための基本構文1.1.1. シンプルなテーブ...

nginx と openssl で https を実装する方法

サーバーデータがSSL証明書を使用して暗号化および認証されていない場合、ユーザーのデータはプレーンテ...

JavaScript DOMContentLoaded イベントのケーススタディ

DOMContentLoaded イベント文字通り、DOM がロードされた後に実行されます。 win...