ホームページ >データベース >mysql チュートリアル >MySQL の各グループで最も高い値を持つ行を選択するにはどうすればよいですか?

MySQL の各グループで最も高い値を持つ行を選択するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-24 08:02:11655ブラウズ

How to Select the Row with the Highest Value in Each Group in MySQL?

MySQL: グループ BY クエリでどの行が返されるかを制御する

MySQL では、各グループから最高値を持つ行を取得します。共通のタスク。ただし、標準の GROUP BY 句を ORDER BY とともに使用すると、予期しない結果が生じる場合があります。

これを実現するには、デフォルトのグループ化動作をオーバーライドする別のアプローチを採用できます。

サブクエリメソッド:

このメソッドには、一意のそれぞれの最大 version_id を取得するサブクエリの作成が含まれます。 id:

SELECT *
FROM (SELECT id, MAX(version_id) AS version_id FROM table GROUP BY id) t1
INNER JOIN table t2 ON (t2.id = t1.id AND t1.version_id = t2.version_id)

このクエリは、元のテーブルを、各 ID の最大の version_id を選択するサブクエリと結合します。結合により、最も高い version_id を持つ行のみが返されることが保証されます。

ORDER BY を使用したサブクエリのトリック:

サブクエリ メソッドのバリエーションには、特定の順序を保証するためのサブクエリ:

SELECT *
FROM (SELECT * FROM table ORDER BY version_id DESC) t1
GROUP BY t1.id

このクエリは行を効果的に並べ替えます。グループ化を実行する前に、各グループ内の version_id の降順で、最も高い version_id を持つ行が各グループに保持されるようにします。

名前付き Windows 関数:

Window関数を使用すると、ウィンドウで定義された一連の行内で計算を実行できます。これは、この目的に使用できます。 task:

SELECT *
FROM (
  SELECT *, ROW_NUMBER() OVER (PARTITION BY id ORDER BY version_id DESC) AS rn
  FROM table
) t
WHERE rn = 1

このクエリは、ROW_NUMBER で定義されたパーティション内の各一意の ID の行番号を計算します。 WHERE 句は、1 以外の行番号を持つ行をフィルターで除外し、各 ID の version_id が最も大きい行のみが返されるようにします。

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

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。