ホームページ > データベース > mysql チュートリアル > SQLで各グループの最大値を見つけるにはどうすればよいですか?

SQLで各グループの最大値を見つけるにはどうすればよいですか?

Linda Hamilton
リリース: 2025-01-07 21:30:41
オリジナル
967 人が閲覧しました

How to Find the Maximum Value for Each Group in SQL?

SQLグループ最大値検索方法

この記事では、複数の「名前」を含むが異なる「合計」値を含むテーブルから、一意の各「名前」に対応する最大の「合計」値レコードを抽出する方法について説明します。

解決策の 1 つは、サブクエリを使用することです。

<code class="language-sql">SELECT
  Name, Top, Total
FROM
  sometable
WHERE
  Total = (SELECT MAX(Total) FROM sometable i WHERE i.Name = sometable.Name);</code>
ログイン後にコピー

このサブクエリは各「名前」の最大「合計」値を見つけ、メイン クエリは一致するレコードを除外します。

もう 1 つの方法は、ネストされたクエリを使用することです:

<code class="language-sql">SELECT
  Name, Top, Total
FROM
  sometable
INNER JOIN (
    SELECT MAX(Total) AS Total, Name
    FROM sometable
    GROUP BY Name
  ) AS max ON max.Name = sometable.Name AND max.Total = sometable.Total;</code>
ログイン後にコピー

このネストされたクエリは、各「名前」の最大「合計」値を含む一時テーブルを作成します。次に、メインクエリは、「name」と「total」の値が一致するこの一時テーブルと sometable テーブルを結合します。接続の結果は、それぞれの一意の「名前」に対応する最大「合計」値のレコードです。

以上がSQLで各グループの最大値を見つけるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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