MySQL を別の列でグループ化し、最大の列値を持つ行を検索します
データベースでは、別の列でグループ化された最大値を持つ行を見つけるのが一般的な分析タスクです。 MySQL では、これは集約とフィルタリングを組み合わせることによって実現できます。
この記事では、別の列で定義された各グループ内の特定の列の最大値を含む行をテーブルから取得する問題について説明します。たとえば、提供された「TopTen」テーブルでは、タスクは、一意の「home」値ごとに行を抽出し、対応する「datetime」列の最大値を抽出することです。
最初に試行されたクエリは次のとおりでしたが、欠陥がありました:
<code class="language-sql">SELECT s1.id, s1.home, s1.datetime, s1.player, s1.resource FROM TopTen s1 JOIN (SELECT id, MAX(`datetime`) AS dt FROM TopTen GROUP BY id) AS s2 ON s1.id = s2.id ORDER BY `datetime`</code>
クエリは、各「ホーム」の最大「日時」値を正しく識別しません。 問題を正しく解決するには、「home」と「datetime」の両方をサブクエリでグループ化する必要があります:
<code class="language-sql">SELECT tt.* FROM topten tt INNER JOIN (SELECT home, MAX(datetime) AS MaxDateTime FROM topten GROUP BY home) groupedtt ON tt.home = groupedtt.home AND tt.datetime = groupedtt.MaxDateTime</code>
この最後のクエリは、「datetime」列の最大値を含む異なる「home」値を持つ各行を正常に識別し、期待どおりの結果が得られます。
id | home | datetime | player | resource |
---|---|---|---|---|
1 | 10 | 04/03/2009 | john | 399 |
2 | 11 | 04/03/2009 | juliet | 244 |
5 | 12 | 04/03/2009 | borat | 555 |
8 | 13 | 01/01/2009 | borat | 700 |
以上がMySQL で別の列でパーティション化された最大列値を持つ行を検索する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。