ホームページ > データベース > mysql チュートリアル > PostgreSQL で単一のコピーを保持したまま重複行を削除するにはどうすればよいですか?

PostgreSQL で単一のコピーを保持したまま重複行を削除するにはどうすればよいですか?

Linda Hamilton
リリース: 2025-01-06 10:05:40
オリジナル
131 人が閲覧しました

How Can I Delete Duplicate Rows in PostgreSQL While Preserving a Single Copy?

単一コピーの保持: 同一でない重複行の削除

データの整合性を維持するには、多くの場合、データベースから冗長なレコードを削除します。ただし、特定のシナリオでは、重複行の各グループのコピーを 1 つ保持する必要がある場合があります。この記事では、PostgreSQL の一連の重複から 1 行を除くすべての行を削除するという課題に取り組みます。

解決策: 一意の識別子を使用した選択的削除

ソリューションで提供されるクエリグループ化と、重複の各グループ内の一意の識別子フィールドの最小 (または最大) 値の選択の概念を利用します。最小 (または最大) の識別子を持つ行を削除プロセスから除外することで、一意の各行の 1 つのコピーを保存できます。

次のクエリは、このアプローチを示しています。

DELETE FROM foo
WHERE id NOT IN (SELECT min(id) FROM foo GROUP BY hash);
ログイン後にコピー

Inこのクエリでは、ハッシュ フィールドは重複セットを定義する一意の特性または特性の組み合わせを表します。各グループから最小の ID 値を選択することで、クエリは保持される行を特定し、残りの重複行を削除から除外します。

以上がPostgreSQL で単一のコピーを保持したまま重複行を削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート