首页 >数据库 >mysql教程 >如何在 PostgreSQL 中对独特公司和职业的连续年份进行分组?

如何在 PostgreSQL 中对独特公司和职业的连续年份进行分组?

DDD
DDD原创
2025-01-09 13:36:411038浏览

How to Group Consecutive Years for Unique Companies and Professions in PostgreSQL?

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn