如何连接顺序值

How to join sequential values

我确实有一个包含 2 种记录的文件,parents 和 children:

id type filler
-- ---- ------
1  1500 h1
2  1501 d11
3  1501 d12
4  1501 d13
5  1500 h2
6  1501 d21
7  1501 d22
...

我想将记录 1501 加入相应的 1500 记录,因此,结果必须类似于:

id1 type filler  id2 type filler2
--- ---- ------  --- ---- -------
1   1500 h1      2   1501 d11
1   1500 h1      3   1501 d12
1   1500 h1      4   1501 d13
5   1500 h2      6   1501 d21
5   1500 h2      7   1501 d22
...

有没有办法加入这样的 parent-child 记录?

要从 id 和 type 获取顺序,最简单的可能是使用常见的 table 表达式将行标记为它们的组,然后加入同一组的行以获得结果,接近;

WITH cte AS (  
  SELECT *, CASE WHEN type < LAG(type) OVER (ORDER BY id) THEN 1 END cnt 
  FROM mytable
), cte2 AS (                        
  SELECT id, type, filler, COUNT(cnt) OVER (ORDER BY id) tag FROM cte
) 
SELECT a.id, a.type, a.filler, b.id, b.type, b.filler 
FROM cte2 a 
JOIN cte2 b 
  ON a.tag = b.tag
WHERE a.type = 1500 AND b.type = 1501
ORDER BY a.id, b.id



 id | type | filler | id | type | filler
----+------+--------+----+------+--------
  1 | 1500 | h1     |  2 | 1501 | d11
  1 | 1500 | h1     |  3 | 1501 | d12
  1 | 1500 | h1     |  4 | 1501 | d13
  5 | 1500 | h2     |  6 | 1501 | d21
  5 | 1500 | h2     |  7 | 1501 | d22