在 PostgreSQL 中擷取按類別分組的最大日期 ID
在資料庫操作中,經常需要根據特定條件擷取記錄。其中一項任務涉及為給定資料集中的每個類別選擇具有最大日期的 ID。這可以在 PostgreSQL 中使用 DISTINCT ON 子句有效地實現。
考慮以下範例資料:
id category date 1 a 2013-01-01 2 b 2013-01-03 3 c 2013-01-02 4 a 2013-01-02 5 b 2013-01-02 6 c 2013-01-03 7 a 2013-01-03 8 b 2013-01-01 9 c 2013-01-01
選擇每個ID 具有最大日期類別,您可以使用以下查詢:
SELECT DISTINCT ON (category) id -- , category, date -- any other column (expression) from the same row FROM tbl ORDER BY category, date DESC;
解釋:
date DESC:
這種降序排序確保首先檢索每個類別中具有最大日期的記錄。7 2 6
此查詢的結果將是:
請注意,DISTINCT ON 在以下情況下特別有用:存在具有相同最大日期的多個記錄。在這種情況下,它提供了一種為每個類別選擇第一個唯一記錄的方法。以上是如何檢索 PostgreSQL 中每個類別的最大日期 ID?的詳細內容。更多資訊請關注PHP中文網其他相關文章!