MySQL の結合クエリとサブクエリの問題

MySQL の結合クエリとサブクエリの問題

複数テーブル結合の基本構文

マルチテーブル接続とは、複数のテーブルを1つのテーブルに結合してクエリを実行することです。

フィールド1、フィールド2、...を選択します。
テーブル1から{inner|lift|right}テーブル2を結合
接続条件について

部門テーブルと従業員テーブルの2つのテーブルがあります。

クロス結合と直積現象

クロスコネクト

クロス結合(無条件内部結合/カルテシアン結合とも呼ばれる)

最初のテーブルの各項目は、他のテーブルの各項目と順番に結合されます。

従業員、部門から*を選択します。 

上記の結果は、明らかに私たちが知りたいことではありません。左のテーブルの各人には 4 つの部門があります。これらの 4 つのレコードを注意深く見ると、左のテーブルの各レコードを右のテーブルと 1 つずつ照合した結果とまったく同じです。

デカルト積現象

デカルト積現象の原因: 2 つのテーブル間に有効な接続条件がありません。結合条件がないので、このテーブルの最初の行は、他のテーブルのすべての行と確実に 1 対 1 で一致させることができます。同様に、このテーブルの 2 番目の行は、他のテーブルのすべての行と確実に 1 対 1 で一致させることができます。同様に、このテーブルの最後の行 m も、他のテーブルのすべての行と 1 対 1 で一致させることができます。他のテーブルに n 行ある場合、最後に表示される行数は m*n 行になります。

デカルト積現象を発生させたくない場合は、有効なテーブル結合条件を追加する必要があります。上記の例では、左側のテーブル dep_id は、右側のテーブル id と等しい場合にのみ、その部門を表します。

内部結合

INNER JOIN は、複数のテーブルの交差部分を見つけること、つまり条件に基づいて正しい結果をフィルタリングすることです。

emp.id、emp.name、emp.age、emp.dep_id、emp.gender、dep.id、dep.name を選択してください
従業員をempとしてINNER JOINし、部門をdepとしてINNER JOINする
emp.dep_id=dep.id の場合; 

department テーブルにはid=5の部門が存在しないため、employee テーブル内のdep_id=5のレコードは返されません。また、行政部従業員が存在しないため、このレコードも返されません。

外部結合

左外部結合

左結合は左テーブルに基づいています。右テーブルに適切なレコードがない場合、 NULLで埋められます。その本質は、左テーブルには結果があるが右テーブルにはないレコードを内部結合に基づいて追加することです (内部結合の場合、この場合のレコードは無視されます)。

emp.id、emp.name、emp.age、emp.dep_id、emp.gender、dep.id、dep.name を選択してください
従業員が emp として退職し、部門が dep として参加
emp.dep_id=dep.id の場合; 

右外部結合

左結合の反対で、右結合は右テーブルに基づいています。左テーブルの一部のフィールドに適切な結果がない場合、 NULLで埋められます。その本質は、右テーブルには結果があるが左テーブルにはないレコードを内部結合に基づいて追加することです (内部結合の場合、この場合のレコードは無視されます)。

emp.id、emp.name、emp.age、emp.dep_id、emp.gender、dep.id、dep.name を選択してください
従業員から emp として右結合部門から dep として
emp.dep_id=dep.id の場合; 

完全外部結合

内部結合に基づく完全外部結合では、左側のテーブルと右側のテーブルのすべてのレコードが表示され、左側のテーブルと右側のテーブルのデフォルト レコードはNULLで埋められます。

MySQL には完全外部結合用のFULL JOIN構文はありませんが、 UNION/UNION ALLステートメントを使用して実装されます。

UNIONUNION ALLの違いは、 UNIONは重複排除機能があることです。

emp.id、emp.name、emp.age、emp.dep_id、emp.gender、dep.id、dep.name を選択してください
従業員が emp として退職し、部門が dep として参加
emp.dep_id=dep.id で
連合
emp.id、emp.name、emp.age、emp.dep_id、emp.gender、dep.id、dep.name を選択してください
従業員から emp として右結合部門から dep として
emp.dep_id=dep.id の場合; 

サブクエリ

  • サブクエリは、クエリ ステートメントを別のクエリ ステートメント内にネストするクエリ メソッドです。
  • サブクエリの内部クエリ結果は、クエリ条件を提供するための外部クエリ ステートメントとして使用できます。
  • サブクエリには、 INNOT INANDALLEXISTSNOT EXISTSなどのキーワードを含めることができます。

サブクエリには=!=><などの比較演算子も含めることができます。

-- 平均年齢が20歳以上の部門名を検索する
部門から
idが(
dep_idを選択
従業員から
dep_id でグループ化
平均年齢が20歳を超える

-- 財務部門の従業員の名前を照会する名前を選択 
従業員から
dep_idが(
IDを選択 
部門から 
where name='財務部');


-- 平均年齢より上のすべての従業員の年齢と名前を照会します。select name,age 
従業員から 
年齢 > (
従業員から平均年齢を選択します。 

これで、MySQL の結合クエリとサブクエリの問題に関するこの記事は終了です。MySQL の結合クエリとサブクエリに関するより関連性の高い情報については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL マルチテーブル結合クエリの詳細な説明
  • どのような種類の MYSQL 接続クエリを知っていますか?
  • MySQL接続クエリの原理と応用
  • MySQL 結合クエリ構文と例
  • MySQLの結合クエリ、ユニオンクエリ、サブクエリの原理と使用例の詳細な説明
  • Mysql 自己結合クエリ例の詳細な説明
  • MySQL マルチテーブル結合クエリ例の説明
  • MySQL接続クエリの詳細な説明

<<:  丸い角や鋭い角を表現するために、絵の代わりに文字を使用する研究

>>:  CSSの4種類の配置の違いの詳細な説明

推薦する

重複したMySQLレコードを現場でチェックし、処理する実践的な記録

目次序文分析するデータ合計繰り返し率どこにあるかと持っているかの違い要約する序文私はソフトウェアの導...

ウェブデザイナーが持つべき7つのスキル

Web デザインは科学であると同時に芸術でもあります。 Web デザイン作業は、半分は適切なプログラ...

nginx がアップストリーム アドレスにジャンプしない問題の解決方法

序文今日、nginx で非常に奇妙な問題に遭遇しました。フロントエンドの tomcat がページにジ...

Webデザイン講座(4):素材と表現について

<br />前回のWebデザインチュートリアル:Webデザインチュートリアル(3):デザ...

HTML の表の行と列を結合する問題の解決策の詳細な説明

私たちが構築しようとしていたウェブサイトには、長い文章だけでなく、多数の表も含まれており、表のレイア...

Linux で xargs コマンドを使用する詳細なチュートリアル

みなさんこんにちは。私は梁旭です。 Linux を使用しているときに、いくつかのコマンドを連結する必...

練習と面接のための Linux シェル スクリプトのヒント 9 つを共有する

予防1) 先頭にインタープリターを追加します: #!/bin/bash 2) 構文のインデントに 4...

JavaScript 基礎シリーズ: 関数とメソッド

目次1. 関数とメソッドの違い2. 良い関数の書き方2.1 正確な命名2.1.1 関数の命名2.1....

Windows Server 2016 標準キー アクティベーション キー シリアル番号

Windows Server 2016 アクティベーション キーを皆さんと共有したいと思います。wi...

Dockerコンテナレイヤーの概念の詳細な説明

目次01 コンテナの一貫性02 レイヤーの概念03 レイヤードデザインの利点今日はコンテナ レイヤー...

MySQLカスケードレプリケーションの実装方法の例

いわゆるカスケード レプリケーションでは、マスター サーバーが 1 つのスレーブ サーバーにのみデー...

js を使用して XML オンライン エディターを作成する例

目次序文オンラインXMLエディタの必要性テクノロジー事前調査ビジュアルプログラミングVSCODEプラ...

js におけるイベントバブリングとイベントキャプチャの簡単な分析

目次01-イベントバブリング1.1- イベントバブリングの概要1.2-イベントバブリングの利用(イベ...

仮想マシンに Linux rhel7.3 オペレーティング システムをインストールする (具体的な手順)

仮想化ソフトウェアをインストールする仮想マシンにオペレーティング システムをインストールする前に、ホ...

ブロックレベル要素、インライン要素、可変要素の概要

ブロック要素p - 段落テキストの事前フォーマットテーブルol - ソートフォームul - 順序なし...