ホームページ >データベース >mysql チュートリアル >データをグループ化した後、行数に基づいてグループをフィルタリングするにはどうすればよいですか?
数によるグループ化とフィルタリング
グループ内の行をカウントすることで結果を集計し、その数に基づいて結果をフィルタリングすることができます。これは、集計関数にフィルター条件を適用できる 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 サイトの他の関連記事を参照してください。