MySQLの自己接続と結合の詳細な理解

MySQLの自己接続と結合の詳細な理解

1. MySQL 自己接続

MySQL では、情報を照会するときに自分自身に接続 (自己接続) する必要がある場合があるため、テーブルのエイリアスを定義する必要があります。例を見てみましょう。以下は商品購入表です。購入価格がHuihuiよりも高いすべての情報を見つける必要があります。

一般的に言えば、この表を見ると、まず次のようなステートメントで操作します。

ショッピングから*を選択 WHERE price>27

ご想像のとおり、これは非常に簡単です。データベース テーブルの詳細なデータがわからない場合や、データの量が非常に多い場合はどうすればよいでしょうか。データベース管理者は、必要なデータをすばやく見つけるために他の方法を使用する必要があります。

ステップバイステップのクエリ

最も簡単な方法は、最も簡単に思いつく方法でもあります。

SELECT price FROM shopping WHERE name='惠惠' //価格クエリの結果は27です
ショッピングから*を選択 WHERE price>27

自己接続方式と比較すると、この方法では中間結果に対する手動介入が必要であり、プログラム内の自動処理操作には明らかに役立ちません。

セルフ接続方式:

b.*を選択 
Aとしての買い物からBとしての買い物まで
ここで、a.name='惠惠' 
そしてa.価格<b.価格 
b.idで注文

次のテーブル情報を取得できます。


注記:

エイリアス a と b は名前が異なりますが、同じテーブルです。エイリアスを定義する目的は、エイリアスの削除や選択を容易にすることです。

select through (中間テーブル) を実行して、最終結果である b.* を取得します。

サブクエリ

サブクエリもよく使用される方法で、select 内に select をネストします。

実装コードは次のとおりです。

ショッピングから*を選択 
WHERE price>(name='惠惠' の 'shopping' から価格を選択)

結果は以下に示されており、両方の方法で得られた結果は同じであることがわかります。


参加する

内部結合

内部結合の主な機能は、テーブル内に少なくとも 1 つの一致がある場合に結果セットを返すことです。ここでの内部結合と結合は同じ機能を持つため、一緒に紹介します。
以下に、商品テーブルとカテゴリ テーブルの 2 つのテーブルを示します。

SELECT * FROM goods INNER JOIN category 
ON goods.id=カテゴリー.goods_id 
gods.idで注文する

結果は以下のようになります。

左結合

LEFT JOIN キーワードは、右側のテーブル (table_name2) に一致する行がない場合でも、左側のテーブル (table_name1) のすべての行を返します。プロジェクトを実行するときは左結合を使用することをお勧めします。ただし、テーブルの関連付けが多数あり、1 つのテーブルが a に左結合されていると同時に、b に右結合されています。この場合、右結合を追加すると、記述が簡単になる場合があります。

最初の 2 つのテーブルを適用して、左結合クエリを実行します。

SELECT goods.*,category.cate_name 
商品から左へカテゴリを結合 
ON goods.id=カテゴリー.goods_id 
goods.idで注文する


右結合

RIGHT JOIN キーワードは、左側のテーブル (table_name1) に一致する行がない場合でも、右側のテーブル (table_name2) のすべての行を返します。最初の 2 つのテーブルを適用して、右結合クエリを実行します。

a.goods_name、a.price、b.* を選択
商品として
RIGHT JOIN カテゴリを b として
オン a.id=b.goods_id
b.idで注文


複数テーブルの関連付けの場合は、関連付けステートメントをいくつか追加するだけです。

要約する

上記はこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に少しでもお役に立てれば幸いです。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM をご愛顧いただき、ありがとうございます。

以下もご興味があるかもしれません:
  • MySQL の複数の左結合クエリの使用状況の分析
  • MySQL の最適化: サブクエリの代わりに結合を使用する
  • MySQL クエリの最適化: 結合クエリのソート制限の概要 (結合、順序、制限ステートメント)
  • MySQL で JOIN ステートメントを使用して接続操作を実行する詳細なチュートリアル
  • MySQL 結合クエリの原則の知識ポイント
  • MySQL 結合クエリ構文と例
  • MySQLでよく使用されるいくつかの結合接続方法の概要

<<:  jQueryはマウスドラッグ画像機能を実装します

>>:  Linux で txt を mysql にインポートする方法

推薦する

lastInfdexOf 関数の MySQL 実装例

MySQL では lastIndexOf に似た関数を使用する必要がある場合もありますが、すぐに使用...

Bash スクリプトを使用して Linux のメモリ使用量を監視する方法

序文Linux システムのパフォーマンスを監視するために使用できるオープンソースの監視ツールが市場に...

Linux で killall コマンドを使用してプロセスを終了する 8 つの例

Linux コマンドラインには、プロセスを強制終了するためのコマンドが多数用意されています。たとえば...

アプレットにおけるwx.getUserProfileインターフェースの具体的な使用

最近、WeChatミニプログラムは、監査ミニプログラムのwx.loginおよびwx.getUserI...

この構成ファイルの排他ロックに失敗したという VMware 仮想マシンのプロンプトの解決方法

VMware が異常シャットダウンした後、再起動すると「この構成ファイルを排他的にロックできませんで...

VMware IOInsight を使用して、仮想マシンのストレージ パフォーマンスの監視を改良する

例: VMware IOInsight は、VM のストレージ I/O 動作を理解するのに役立つツー...

HTML テキストフォーマットの簡単な例 (詳細な説明)

1. テキストの書式設定: この例では、HTML ファイル内のテキストを書式設定する方法を示します...

史上最も簡単な MySQL データのバックアップと復元のチュートリアル (パート 2) (パート 37)

データのバックアップと復元パート3の詳細は次のとおりです基本的な概念:バックアップ、現在のデータまた...

MySQL の悲観的ロックと楽観的ロックの理解と応用分析

この記事では、例を使用して MySQL の悲観的ロックと楽観的ロックについて説明します。ご参考までに...

OEL7.6 ソースコードから MYSQL5.7 をインストールするチュートリアル

まず、公式サイト https://dev.mysql.com/downloads/mysql/5.7...

Linux コマンドラインからファイルを削除する実用的な方法

rm コマンドrm コマンドは、ファイルを削除するときによく使用されるコマンドです。ファイルまたはデ...

Ubuntu 18.04 のすべての Python ライブラリを一度にアップグレードする方法

ピップとは何かpip は、Python パッケージの検索、ダウンロード、インストール、アンインストー...

HTML ページ共通スタイル (推奨)

以下のように表示されます。 XML/HTML コードコンテンツをクリップボードにコピーbody、di...

HTMLからPDFへの変換のための純粋なクライアント側と純粋なサーバー側の実装ソリューション

必要ユーザーがフォームに入力して「保存」をクリックすると、PDF ドキュメントを直接ダウンロードでき...