PostgreSQL 9.0 中对连续年份进行分组
本文探讨如何在 PostgreSQL 9.0 中对连续年份进行分组,同时获取唯一的公司和职业信息。
我们将采用多步方法实现此目标。首先,我们使用子查询确定非连续年份,该子查询根据年份是否为序列中的第一个年份或当前年份与前一年年份的差值是否大于 1 来分配“group_cnt”值。
下一步,我们通过对每个公司和职业的排序年份的 group_cnt 值求和来定义组 ID。这为非连续年份创建连续的组。
最后,我们利用另一个派生表根据组 ID 聚合年份。结果是每个唯一公司和职业的年份数组,其中连续年份被分组在一起。
示例查询:
<code class="language-sql">SELECT company, profession, array_agg(year) AS years FROM ( SELECT company, profession, year, SUM(group_cnt) OVER (ORDER BY company, profession, year) AS group_nr FROM ( SELECT company, profession, year, CASE WHEN ROW_NUMBER() OVER (PARTITION BY company, profession ORDER BY year) = 1 OR year - LAG(year,1,year) OVER (PARTITION BY company, profession ORDER BY year) > 1 THEN 1 ELSE 0 END AS group_cnt FROM qualification ) t1 ) t2 GROUP BY company, profession, group_nr ORDER BY company, profession, group_nr;</code>
输出:
<code> company | profession | years ---------+------------+------------------ Google | Programmer | {2000} Google | Sales | {2000,2001,2002} Google | Sales | {2004} Mozilla | Sales | {2002} (4 rows)</code>
以上是如何在 PostgreSQL 中对独特公司和职业的连续年份进行分组?的详细内容。更多信息请关注PHP中文网其他相关文章!