如何使用 generate_series() 生成值网格
How to use generate_series() to generate a grid of values
我想生成(行,列)对的网格,例如:
1 | 1
1 | 2
1 | 3
...
2 | 1
2 | 2
...
我天真的方法有这种令人费解的行为:
select generate_series(1,5), generate_series(1, 5);
generate_series | generate_series
-----------------+-----------------
1 | 1
2 | 2
3 | 3
4 | 4
5 | 5
(5 rows)
select generate_series(1,5), generate_series(1, 4);
generate_series | generate_series
-----------------+-----------------
1 | 1
2 | 2
3 | 3
4 | 4
5 | 1
1 | 2
2 | 3
3 | 4
4 | 1
5 | 2
1 | 3
2 | 4
3 | 1
4 | 2
5 | 3
1 | 4
2 | 1
3 | 2
4 | 3
5 | 4
(20 rows)
似乎重复每个系列,直到到达具有每个系列最终值的一行。
将此函数用作与自身交叉连接的正确方法是什么?
将函数调用移至 FROM
子句:
SELECT *
FROM generate_series(1,5) a
, generate_series(1,5) b;
或者升级到 Postgres 10 或更高版本,最终改变了这种奇怪的行为。详细解释:
逗号分隔的 FROM
项交叉连接。参见:
我想生成(行,列)对的网格,例如:
1 | 1
1 | 2
1 | 3
...
2 | 1
2 | 2
...
我天真的方法有这种令人费解的行为:
select generate_series(1,5), generate_series(1, 5);
generate_series | generate_series
-----------------+-----------------
1 | 1
2 | 2
3 | 3
4 | 4
5 | 5
(5 rows)
select generate_series(1,5), generate_series(1, 4);
generate_series | generate_series
-----------------+-----------------
1 | 1
2 | 2
3 | 3
4 | 4
5 | 1
1 | 2
2 | 3
3 | 4
4 | 1
5 | 2
1 | 3
2 | 4
3 | 1
4 | 2
5 | 3
1 | 4
2 | 1
3 | 2
4 | 3
5 | 4
(20 rows)
似乎重复每个系列,直到到达具有每个系列最终值的一行。
将此函数用作与自身交叉连接的正确方法是什么?
将函数调用移至 FROM
子句:
SELECT *
FROM generate_series(1,5) a
, generate_series(1,5) b;
或者升级到 Postgres 10 或更高版本,最终改变了这种奇怪的行为。详细解释:
逗号分隔的 FROM
项交叉连接。参见: