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:
表2:
左結合:等価条件に基づいてテーブルを結合します。この実験は、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 を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
>>: Gogs+Jenkins+Docker による .NetCore ステップの自動デプロイ
この記事の例では、参考のために航空機戦争ゲームを実装するためのJSの具体的なコードを共有しています。...
皆様の参考と操作を容易にするために、様々な主要ウェブサイトを検索し、関連するスケジュールされたタスク...
良い画像素材のウェブサイトを見つけるのは難しいです。特に無料です。良い写真には非常に目を引く視覚効果...
最近、会社初のミニプログラムの開発に参加しました。開発経験は基本的にWebViewをベースとしたハイ...
MongoDB のインストール プロセスと問題記録1. MongoDBのインストールMongoDBを...
GtkTreeView コンポーネントは、美しい通常のリストやツリーのようなリストを作成できる高度な...
ここでは、通常ヘッダーとフッターに対して行われるインクルード ファイルを使用している可能性があります...
目次1. インストール前の準備、インストールパッケージのダウンロード1 インストールの準備2 インス...
参考までに、Javascript を使用して広告を閉じる方法に関するケース スタディを示します。詳細...
目次1. 使い方が簡単2. DISTINCTを使用して重複を削除する3. COUNT()の詳細な紹介...
一般的に、テーブルを使用する場合は、常に <table border="1"...
1. Navicat for MySQL 15をダウンロードするhttps://www.navica...
1. ポート 80 が占有されているかどうかを確認します。通常、ポート 80 は Apache サー...
序文MySQL では、複数テーブル結合クエリは非常に一般的な要件です。複数テーブルクエリを使用する場...
目次1. ファイアウォールの現在の状態を確認する2. ファイアウォールサービスを開始する3. ファイ...