MySQL クエリの重複データ (重複データを削除し、ID が最も小さいデータのみを保持します)

MySQL クエリの重複データ (重複データを削除し、ID が最も小さいデータのみを保持します)

開発の背景:

最近、私はバッチ データを MySQL データベースにインポートする機能に取り組んでいます。バッチ インポートから、そのようなデータはデータベースに挿入される前に重複していると判断されないことがわかります。したがって、すべてのデータがインポートされた後にのみ、データの一意性を確保するためにデータを削除するステートメントが実行されます。

詳しい紹介を見てみましょう。

実戦:

テーブル構造は次の図に示されています。

意味: ブランド

操作:

SQL ステートメントを使用して、重複データがあるかどうかを照会します。

ブランドから*を選択 WHERE brandName IN (
select brandName from brand GROUP BY brandName HAVING COUNT(brandName)>1 #条件は重複データの数が1より大きいことです)

SQL を使用して冗長な重複データを削除し、最小の ID を持つ一意のデータを保持します。

注記:

間違った SQL: DELETE FROM brand WHERE brandName IN (select brandName from brand GROUP BY brandName HAVING COUNT(brandName)>1)
AND Id NOT IN (ブランドから MIN(Id) を選択、GROUP BY brandName、HAVING COUNT(brandName)>1)

ヒント: FROM句で更新のターゲットテーブル「brand」を指定することはできません

理由は、直接見つかったデータは、データを削除する条件として使用できないためです。まず、見つかったデータの一時テーブルを作成し、その一時テーブルを削除の条件として使用する必要があります。

正しいSQLの書き方:
 DELETE FROM brand WHERE brandName IN (SELECT brandName FROM (SELECT brandName FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) e)
 AND Id NOT IN (SELECT Id FROM (SELECT MIN(Id) AS Id FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) t)

#重複データのクエリでは最初の数項目のみが表示されるため、最小値かどうかをクエリする必要はありません。

結果は次のとおりです。


要約:

多くのことは、自分で段階的に調べる必要があります。もちろん、インターネット上の提案も非常に貴重な参考資料やリソースです。どのような開発を行うにしても、それをよりよく習得するには、その動作原理を理解する必要があります。

さて、以上がこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に一定の参考学習価値を持つことを願っています。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM をご愛顧いただきありがとうございます。

以下もご興味があるかもしれません:
  • MySQLテーブル内の重複レコードを見つける
  • 1 つ以上のフィールドに基づいて重複データを検索する MySQL SQL ステートメント
  • MySQLで重複データを見つけて削除し、1つの例だけを残す方法の詳細な説明
  • MySQLテーブル内の重複データをクエリする方法
  • MySQLデータベース内の重複データを削除する方法の概要
  • 重複データを処理するための非常に包括的なMySQLコード
  • MySQL データベース内の重複レコードを削除する方法のまとめ [推奨]
  • MYSQLにデータを挿入する際に重複データを無視する方法を共有する
  • MySQLは重複しないデータ挿入を実装するためにUNIQUEを使用する
  • 重複したMySQLレコードを現場でチェックし、処理する実践的な記録

<<:  React 星評価コンポーネントの実装

>>:  Linux の sudo 脆弱性により不正な特権アクセスが発生する可能性がある

推薦する

Ubuntu Linuxシステムをインストールするときにハードディスクをパーティション分割する最も合理的な方法の詳細な説明

Windows または Linux オペレーティング システムをインストールするかどうかに関係なく、...

MySQL サービスとデータベース管理

目次1. サービスの開始と停止の手順1.1 Windows での MySQL 5.7 の公式 MSI...

Node.js のモジュール性、npm パッケージ マネージャーの説明

目次モジュール化の基本概念モジュール化とは何かモジュール分解の利点Node.js のモジュール性No...

MySQL テーブルを削除するときに外部キー制約を無視するシンプルな実装

テーブルを削除することはあまり一般的ではありませんが、特に外部キーの関連付けがあるテーブルの場合は、...

Vue はチャット ボックスで絵文字を送信する機能を実装します

vueチャットボックスで絵文字を送信し、vueインターフェースで絵文字を送信するための具体的なコード...

JSONP クロスドメインシミュレーション Baidu 検索

目次1. JSONPとは何か2. JSONPクロスドメインリクエスト3. Baidu検索をシミュレー...

IE、Firefox、Chromeブラウザではスペースの表示が異なります

&nbsp;&nbsp;IE、Firefox、Chrome ブラウザでの表示効果は、...

1 つの記事で MySQL のプリコンパイルを理解する

1. プリコンパイルの利点私たちは皆、プリコンパイル機能を備えた JDBC の PreparedSt...

iviewは動的なフォームとカスタム検証期間の重複を実装します

フォーム項目を動的に追加するiview の動的なフォーム追加は非常に簡単です。フォーム項目を配列に設...

MySQLバッチは特定のフィールドのスペースを削除します

Mysql で特定のフィールドからスペースを一括削除する方法はありますか?文字列の前後のスペースだけ...

Linux で NFS ファイル共有サーバーを構築するための詳細な手順

Linux が NFS サーバーを構築異なるオペレーティング システム間でデータを共有するために、通...

MySQLデータの同時更新を処理する方法

UPDATE はロックしますか?以下のような場合、SQL文はロックされますか? テーブル1を更新しま...

Axiosは繰り返しのリクエストをキャンセル

目次序文1. リクエストをキャンセルする方法2. 重複リクエストの判定方法3. 繰り返しリクエストを...

MySQL 5.7.18 winx64 のインストールと設定方法のグラフィックチュートリアル

圧縮パッケージのインストールは、mysql-5.7 以降、大幅に変更されました。この記事では、mys...

JavaScriptを使って動的にテーブルを生成するケースの詳しい説明

目次序文実装のアイデア実装コード成果を達成する序文これは、テーブルを動的に追加する例です。[追加] ...