ホームページ > データベース > mysql チュートリアル > 複数のフィールド (電子メールや名前など) に基づいて SQL テーブル内の重複行を見つける方法

複数のフィールド (電子メールや名前など) に基づいて SQL テーブル内の重複行を見つける方法

Barbara Streisand
リリース: 2025-01-23 02:10:08
オリジナル
660 人が閲覧しました

How to Find Duplicate Rows in a SQL Table Based on Multiple Fields (e.g., Email and Name)?

複数のフィールドに基づいた SQL の重複レコードの識別

SQL テーブル内の重複の検索は、フィールドが 1 つあれば簡単です。 ただし、電子メールや名前など、複数のフィールドにわたる重複を特定するには、より洗練されたアプローチが必要です。 この例では、電子メールと名前の両方に基づいて重複エントリを見つける方法を示します。

このソリューションでは、複数のフィールドを含めるように変更された GROUP BY 句を使用します。

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

nameemail によるグループ化により、同じ電子メールと名前の組み合わせを持つレコードが確実にグループ化されます。次に、HAVING 句でこれらのグループをフィルタリングし、COUNT(*) (わかりやすくするために DuplicateCount に名前変更) が 1 より大きいグループのみを返し、重複エントリを特定します。 これにより、名前と電子メールのペアが重複する行が効果的に識別されます。

以上が複数のフィールド (電子メールや名前など) に基づいて SQL テーブル内の重複行を見つける方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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