SQL: 各グループ内の最大値を持つレコードを特定します
3 つのフィールド (名前、最高値、合計) とデータを含むテーブルがあり、タスクは異なる名前ごとに最高の合計値を持つレコードを取得することであるとします。
解決策:
次のクエリは、目的の結果を返します:
<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>
以上がSQLで各グループの最大値を持つレコードを見つけるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。