ホームページ >データベース >mysql チュートリアル >データをグループ化した後、行数に基づいてグループをフィルタリングするにはどうすればよいですか?

データをグループ化した後、行数に基づいてグループをフィルタリングするにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-12-29 21:38:47353ブラウズ

How Can I Filter Groups Based on Row Count After Grouping Data?

数によるグループ化とフィルタリング

グループ内の行をカウントすることで結果を集計し、その数に基づいて結果をフィルタリングすることができます。これは、集計関数にフィルター条件を適用できる HAVING 句を使用して実現できます。

使用法:

次のクエリは、HAVING の使用方法を示しています。結果をカウントでフィルターするには:

SELECT name, COUNT(*)
FROM mytable
GROUP BY name
HAVING COUNT(*) > 1

このクエリでは、まず 'mytable' 内の行を次の基準でグループ化します。 「名前」列。 COUNT(*) 集計関数は、各グループ内の行数をカウントします。その後、HAVING 句によって結果がフィルター処理され、カウントが 1 より大きいグループのみが含まれます。

例:

次の表を考えてみましょう:

name
John
Mary
John
Jane
Jane
Mark

上記のクエリは次の値を返します。 result:

name COUNT(*)
John 2
Jane 2

ご覧のとおり、「John」グループと「Jane」グループのみが返されます。これらのグループのカウントは 1 より大きいためです。

以上がデータをグループ化した後、行数に基づいてグループをフィルタリングするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。