合 PG中的行转列
Tags: PGPostgreSQL行转列
简介
PG有如下几种行转列写法:
1、group by + sum + case when
2、用postgresql的crosstab函数
3、group by + string_agg + split_part(分组,行转列,字符切割)
4、使用json函数
环境准备
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | CREATE TABLE sales ( year INTEGER, quarter INTEGER, sales_amount NUMERIC ); INSERT INTO sales VALUES (2018, 1, 100), (2018, 2, 200), (2018, 3, 300), (2018, 4, 400), (2019, 1, 500), (2019, 2, 600), (2019, 3, 700), (2019, 4, 800); |
我们想将每个季度的销售额作为一列,年份作为行,结果:
1 2 3 4 5 | year | q1 | q2 | q3 | q4 ------+-----+-----+-----+----- 2018 | 100 | 200 | 300 | 400 2019 | 500 | 600 | 700 | 800 (2 rows) |
方法1:使用crosstab函数
PostgreSQL中可以使用crosstab函数将行转列,需要使用一个额外的模块“tablefunc”,安装完成后,我们可以使用crosstab函数将行转列。
1 2 3 4 5 6 7 8 9 10 | CREATE EXTENSION tablefunc; SELECT * FROM crosstab( 'SELECT year, quarter, sales_amount FROM sales ORDER BY 1, 2', 'SELECT quarter FROM generate_series(1,4) AS quarter' ) AS sales_pivot(year INTEGER, q1 NUMERIC, q2 NUMERIC, q3 NUMERIC, q4 NUMERIC); |
在这个例子中,我们将查询作为第一个参数传递给crosstab函数。查询必须按年份和季度排序。第二个参数是一个子查询,用于生成列名。在本例中,我们使用generate_series函数生成1到4之间的数字作为季度列的名称。