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