ホームページ > データベース > mysql チュートリアル > MySQL で別の列でパーティション化された最大列値を持つ行を検索する方法

MySQL で別の列でパーティション化された最大列値を持つ行を検索する方法

Susan Sarandon
リリース: 2025-01-25 06:46:08
オリジナル
383 人が閲覧しました

How to Find Rows with Maximum Column Values, Partitioned by Another Column in MySQL?

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 サイトの他の関連記事を参照してください。

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