MySQL で 2 つのセットの交差/差/和を取得する方法

MySQL で 2 つのセットの交差/差/和を取得する方法

MySQL の一般的なシナリオ: 2 つのデータ セットの交差と差を取得する

ステップ

1. 2つのコレクションの構造は、フィールド数とフィールドタイプが一致していなければなりません。

2. UNION ALL キーワードを使用して 2 つのセットを結合します。結果は重複するすべてのセットになります。

3. 上記のすべてのセットをIDでグループ化する

4. 最後に、HAVING COUNT(id)=1 です。これが 1 に等しい場合、それは 1 回だけ出現することを意味するため、これは差異集合です。これが 2 に等しい場合、これは交差集合です。

コードデモンストレーション

違い

次の SQL には明らかな問題がありますが、これは単なるヒントです。

テーブルからクエリを実行するために、交差と差を使用する必要はありません。条件を組み合わせて直接クエリを実行できます。意味を理解しておくと良いでしょう。

次のSQLは、すべての非技術系従業員のID、コード、名前を検索することを意味します。

a.* から(を選択します
    test_emp から id、コード、名前を選択します。
    ユニオンオール
    test_emp から id、コード、名前を選択します。dept='JSB' を指定します。
)a GROUP BY a.id HAVING COUNT(a.id)=1

交差点

次のSQLは、技術部門の25歳以上の従業員全員を検索することを意味します。

a.* から(を選択します
    test_emp から id、code、name を選択、年齢>25 の場合
    ユニオンオール
    test_emp から id、コード、名前を選択します。dept='JSB' を指定します。
)a GROUP BY a.id HAVING COUNT(a.id)=2

連合

次のSQLは、技術部門の従業員全員と30歳以上の従業員を検索することを意味します。

Unionは重複コンテンツを自動的に削除し、重複のない結果セットを取得できます。

a.* から(を選択します
    test_emp から id、code、name を選択、年齢>25 の場合
    連合
    test_emp から id、コード、名前を選択します。dept='JSB' を指定します。
)

MySQL での交差、結合、差、左結合、右結合

私は1か月間MySQLを学習してきました。この1か月間、必要に応じてデータテーブルに対していくつかの基本的な操作を実行しました。このプロセスでは、左結合、右結合、交差、差集合などを頻繁に使用しました。ここで、その基本的な操作をまとめます。

データソース:

表1:

ID 名前 性別 年齢

1 マイク1 男性 34
1 mike2 男性 23
1 mike3 女性 24
2 mike1 男性 46
2 mike2 男性 35
2 mike3 男性 42
2 マイク4 男性 62
3 mike1 女性 45
4 マイク5 男性 72
5 mike4 女性 23

表2:

id学校

1 北京大学

2 清華大学

3. ハーバード大学

7. マサチューセッツ工科大学

左結合:

等価条件に基づいてテーブルを結合します。この実験は、IDが同じ場合に左結合を実行することです

コード:

a.*、b.schoolを選択 
から 
(SELECT * FROM mike1.test001) から
左結合
(mike1.test003 から id、school を選択) b
オン a.id=b.id

結果は次のようになります。表1を基礎として表2を接続し、同じID番号を一致させます。

右結合:

テーブル 2 をルートとして、同じ ID を持つフィールドを介して右結合します。

コード:

a.*、b.schoolを選択 
から 
(SELECT * FROM mike1.test001) から
右のJOIN
(mike1.test003 から id、school を選択) b
オン a.id=b.id

結果:

結果に問題があると思いますか?

交差点:

同じ ID 番号を使用して、テーブル 1 とテーブル 2 に対して内部結合が実行され、同じ部分が取得され、異なる部分が省略されます。

コード:

a.*、b.schoolを選択 
から 
(SELECT * FROM mike1.test001) から
内部結合
(mike1.test003 から id、school を選択) b
オン a.id=b.id

結果:

違い:

差集合は頻繁に使われますが、これは数学で学んだ積集合、結合集合、和集合などの集合演算に似ています。

コード 1: 表 2 の表 1 と同じ部分を取得します。これは、上記の交差を取得する 2 番目の方法です。

a.id、a.name、a.sex、a.age、b.school を選択してください 
から 
(SELECT * FROM mike1.test001) から
左外部結合
(mike1.test003 から id、school を選択) b
オン a.id=b.id
b.id が null ではない場合

結果:

code2: テーブル 1 の ID とテーブル 2 の ID の差を取得し、最後にデータをリストします。

a.id、a.name、a.sex、a.age、b.school を選択してください 
から 
(SELECT * FROM mike1.test001) から
左外部結合
(mike1.test003 から id、school を選択) b
オン a.id=b.id
b.id が null の場合

結果:

上記は私の個人的な経験です。参考になれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • MySQLはマイナスと交差のテストレポートを実装します
  • MySQLクエリ結果の交差を実装する方法
  • Java8 の差集合、和集合、積集合の例

<<:  CSS floatプロパティの詳細な説明

>>:  Gogs+Jenkins+Docker による .NetCore ステップの自動デプロイ

推薦する

LinuxにMySQLデータベース5.6のソースコードをインストールし、ログインユーザーのパスワードを変更する

この記事では、主に Linux で MYSQL データベースをインストールする方法について説明し、M...

React リストバーとショッピングカートコンポーネントの使用の詳細な説明

この記事では、Reactリストバーとショッピングカートコンポーネントの具体的なコードを参考までに紹介...

VMware Workstation のインストール Linux システム

始める段階から初心者になるまで、Linux オペレーティング システムは不可欠です。最初のステップは...

MYSQL SERVER のログファイルを縮小する方法

トランザクション ログには、関連するデータベースに対する操作が記録され、データベースの回復に関連する...

MySQL トランザクション自動コミット自動コミット操作

MySQL のデフォルトの動作モードは自動コミット モードです。つまり、明示的にトランザクションを開...

JSコンストラクタとインスタンス化およびプロトタイプ導入の関係

目次1. コンストラクタとインスタンス化2. コンストラクターとインスタンス化の関係は何ですか? 3...

Dockerはコード検出プラットフォームSonarQubeを構築し、Mavenプロジェクトのプロセスを検出します

1 はじめに優れたコーディング習慣は優れたプログラマーが備えるべき資質ですが、コードの品質を保証する...

VMware10 での CentOS 7 のインストールと設定のチュートリアル

Ubuntu が今日のデスクトップ ユーザーの間で最も人気のある Linux オペレーティング シス...

Webフロントエンドベクターアイコンの使い方

序文フロントエンドページを書くとき、小さなアイコンなどの画像を使うことが多いです。画像を使うとコード...

負のz-indexを持つ要素がクリックできない問題の解決策

最近、ポップアップ広告に取り組んでいました。デフォルト ページには z-index が設定されていな...

React-vscode で jsx 構文を使用する際の問題と解決策

問題の説明プラグインをインストールした後、ES7 React/Redux/GraphQL/React...

dockerにmysqlをインストールした後にNavicatが接続できない問題に対する完璧な解決策

1. Dockerがイメージをプルするdocker pull mysql (デフォルトで最新バージョ...

MySQLのROUND関数の丸め演算における落とし穴の分析

この記事では、MySQL の ROUND 関数を使用した丸め操作の落とし穴を例を使って説明します。ご...

docker ポートを追加して dockerfile を取得する方法

DockerイメージからDockerfileを取得する docker 履歴 --format {{....

ウェブページで Enter キーを押すと自動的にフォームを送信し、他のページにジャンプするソリューション

ウェブページでEnterキーを押すと、フォームは自動的に送信され、他のページに移動します。クエリフォ...