ホームページ > データベース > mysql チュートリアル > SQL テーブル内の複数の列にまたがる重複行を見つけるにはどうすればよいですか?

SQL テーブル内の複数の列にまたがる重複行を見つけるにはどうすればよいですか?

Patricia Arquette
リリース: 2025-01-23 02:16:09
オリジナル
479 人が閲覧しました

How Can I Find Duplicate Rows Across Multiple Columns in a SQL Table?

SQL テーブル内の複数の列で重複する値を検索します

GROUP BY 句を使用した標準的なアプローチは、単一列内の重複値を効果的に識別します。しかし、名前やメールアドレスなど、複数の列で重複を検索する必要がある場合はどうすればよいでしょうか?

この問題を解決するには、GROUP BY 句を拡張して、関連するすべての列を含めます。

<code class="language-sql">SELECT
    name,
    email,
    COUNT(*)
FROM
    users
GROUP BY
    name, 
    email
HAVING 
    COUNT(*) > 1</code>
ログイン後にコピー

このクエリは、名前と電子メールでグループ化することにより、これら 2 つの列の組み合わせの重複を効果的に特定します。

注: データベース システムが異なれば、この構文のサポートも異なる場合があります。一部の古いバージョンの SQL データベースでは、すべての非集計列を GROUP BY 句に含める必要があります。ただし、PostgreSQL や MySQL などの最新のデータベース エンジンは、非集計列でのグループ化をサポートしていることがよくあります。

関数の依存関係ルールが適用されることに注意してください。つまり、グループ化に使用される列は相互に強い関係を持つ必要があります。関係が弱い場合、予期せぬ結果が生じる可能性があります。

異なるデータベース システム間で一貫した動作を確保するには、すべての非集計列を GROUP BY 句に含めるか、実装の詳細について特定のデータベースのドキュメントを参照することをお勧めします。

以上がSQL テーブル内の複数の列にまたがる重複行を見つけるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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