首页 > 数据库 >PostgreSQL中的行转列

PostgreSQL中的行转列

时间:2023-05-13 15:37:28浏览次数:47  
标签:PostgreSQL agg sales 转列 part split quarter

PG有三种行转列写法:

1、group by + sum + case when

2、用postgresql的crosstab函数

3、group by + string_agg + split_part(分组,行转列,字符切割)

环境准备

 1CREATE TABLE sales (
2    year INTEGER,
3    quarter INTEGER,
4    sales_amount NUMERIC
5);
6
7INSERT INTO sales VALUES
8    (2018, 1, 100),
9    (2018, 2, 200),
10    (2018, 3, 300),
11    (2018, 4, 400),
12    (2019, 1, 500),
13    (2019, 2, 600),
14    (2019, 3, 700),
15    (2019, 4, 800);

我们想将每个季度的销售额作为一列,年份作为行,结果:

1 year | q1  | q2  | q3  | q4
2------+-----+-----+-----+-----
3 2018 | 100 | 200 | 300 | 400
4 2019 | 500 | 600 | 700 | 800
5(2 rows)

方法1:使用crosstab函数

PostgreSQL中可以使用crosstab函数将行转列,需要使用一个额外的模块“tablefunc”,安装完成后,我们可以使用crosstab函数将行转列。

1CREATE EXTENSION tablefunc;
2
3SELECT *
4FROM crosstab(
5    'SELECT year, quarter, sales_amount
6     FROM sales
7     ORDER BY 1, 2',
8    'SELECT quarter FROM generate_series(1,4) AS quarter'
9) AS sales_pivot(year INTEGER, q1 NUMERIC, q2 NUMERIC, q3 NUMERIC, q4 NUMERIC);

在这个例子中,我们将查询作为第一个参数传递给crosstab函数。查询必须按年份和季度排序。第二个参数是一个子查询,用于生成列名。在本例中,我们使用generate_series函数生成1到4之间的数字作为季度列的名称。

crosstab函数将行转换为列,并返回一个新的表。我们在外部查询中指定每个生成的列的数据类型和名称,以便正确返回结果。

方法2:使用group by + sum + case when

使用GROUP BY + SUM + CASE WHEN 也可以实现将行转列的效果。以下是一个示例:

1SELECT
2    year,
3    SUM(CASE WHEN quarter = 1 THEN sales_amount ELSE 0 END) AS q1,
4    SUM(CASE WHEN quarter = 2 THEN sales_amount ELSE 0 END) AS q2,
5    SUM(CASE WHEN quarter = 3 THEN sales_amount ELSE 0 END) AS q3,
6    SUM(CASE WHEN quarter = 4 THEN sales_amount ELSE 0 END) AS q4
7FROM sales
8GROUP BY year
9ORDER BY year;

在这个示例中,我们使用了四个不同的CASE WHEN表达式来计算每个季度的销售额。在每个CASE WHEN表达式中,我们检查季度是否等于1、2、3或4,如果是,就将对应的销售额加入到该季度的总计中。否则,我们将0加入到总计中。

在查询中,我们使用GROUP BY子句对年份进行分组,并对每个季度的销售额进行求和。结果与使用crosstab函数得到的结果相同。

方法3:使用group by + string_agg + split_part(分组,行转列,字符切割)

使用GROUP BY + string_agg + split_part 也可以实现将行转列的效果。以下是一个示例:

 1SELECT
2    year,
3    split_part(sales_agg, ',', 1)::numeric AS q1,
4    split_part(sales_agg, ',', 2)::numeric AS q2,
5    split_part(sales_agg, ',', 3)::numeric AS q3,
6    split_part(sales_agg, ',', 4)::numeric AS q4
7FROM (
8    SELECT
9        year,
10        string_agg(sales_amount::text, ',' ORDER BY quarter) AS sales_agg
11    FROM sales
12    GROUP BY year
13) AS sales_pivot;

在这个示例中,我们使用string_agg函数将每个季度的销售额连接成一个以逗号分隔的字符串(这里一定需要加上order by子句)。然后,我们使用split_part函数将字符串拆分成四个部分,以获取每个季度的销售额,并将其转换为数字类型。最后,我们在外部查询中指定了每个季度的数据类型和名称。

在查询中,我们首先使用GROUP BY子句对年份进行分组,并使用string_agg函数将每个季度的销售额连接成一个以逗号分隔的字符串。然后,我们在外部查询中使用split_part函数将字符串拆分成四个部分,并将其转换为数字类型,以获取每个季度的销售额。结果与使用crosstab函数或GROUP BY + SUM + CASE WHEN得到的结果相同。

 

标签:PostgreSQL,agg,sales,转列,part,split,quarter
From: https://www.cnblogs.com/chuangsi/p/17397452.html

相关文章

  • PostgreSQL中的序列名很长很长怎么办
           PostgreSQL中的序列名很长很长怎么办原创SeanHe数据库杂记2023-05-0606:01发表于上海PostgreSQL中的序列名很长很长怎么办tag:PostgreSQL,数据库移植1.前言我们回忆一下,PostgreSQL好像有对象名不超过63个字符的默认限制。详见:current/limit......
  • PostgreSQL插件(1): pg_timeout及pg_timetable 及 若干FAQ(1)
           PostgreSQL插件(1):pg_timeout及pg_timetable及若干FAQ(1)PostgreSQL2023-05-1209:20发表于河北编者荐语:报考PG数据库专家上盘古云课堂以下文章来源于数据库杂记,作者SeanHe1、前言这次将简单介绍PG的两个插件,以及若干常见问题汇集,作......
  • 记录一次金仓V8R3数据库坏块处理过程、PostgreSQL数据库适用
    因数广政务云华为业务存储固件升级,导致数据库产生坏块,业务SQL查询报错如下:ERROR:missingchunknumber0fortoastvalue38166585inSYS_TOAST_30170CONTEXT:PL/SQLfunctioninline_code_blockline12atFORoverEXECUTEstatement解决办法:1、先查询出SYS_TOAST......
  • PostgreSQL 10 文档: PostgreSQL 客户端工具
    PostgreSQL客户端应用这部份包含PostgreSQL客户端应用和工具的参考信息。不是所有这些命令都是通用工具,某些需要特殊权限。这些应用的共同特征是它们可以被运行在任何主机上,而不管数据库服务器在哪里。当在命令行上指定用户和数据库名时,它们的大小写会被保留—空格或特殊字......
  • python导出postgresql中的一个表到本地csv表格
     代码如下修改xxx即可:conn=psycopg2.connect(host=DB_SERVICES,user=DB_USERNAME,password=DB_PWD,database=DB_NAME)cur=conn.cursor(cursor_factory=psycopg2.extras.DictCursor)sql=f"select*fromxxx.xxx"cur.execute(sql)res=cur.fetchall()pand......
  • postgresql 某字段用逗号分隔,查询某个值是否在其中,以及关联表查询
     1.postgresql某字段用逗号分隔,查询某个值是否在其中比如有个字段值是1,2,3查看1是否在里面selectid,gate_type,gate_namefromyg_gate_base_bwhere'1'=ANY(STRING_TO_ARRAY(gate_type,','))orderbygat......
  • 调优PostgreSQL 14和更早版本的统计信息收集器
    PostgreSQL 15的一项重大改进:PostgreSQL 15:统计收集器不见了?虽然对这个即将到来的改进高兴,但我们可以在以前的版本中看到一些关于“效率低下”的评论。这让我意识到,尽管调整stats collector的特性是官方文档和建议的一部分,而且过去有许多关于它的博客帖子,但我很少看到有人......
  • postgresql 更改目类后.conf的位置和shared_preload_libraries写多个的写法
    postgresql更改目类后.conf的位置和shared_preload_libraries写多个的写法postgresql更改了pgdata后。conf会到新的pgdata里面才能看到 需预加载加载多个的话按下面这样写shared_preload_libraries='pg_strom,pipelinedb'  shared_preload_librariesshared_preloa......
  • PostgreSQL如何查询IO消耗最高的SQL及优化,pg_stat_statements插件安装及使用
    PostgreSQL如何查询IO消耗最高的SQL及优化,pg_stat_statements一、安装pg_stat_statements插件二、加载pg_stat_statements模块三、配置pg_stat_statements采样参数四、创建pg_stat_statementsextension五、分析SQL查询哪些sql语句执行效率慢:重置统计信息普通用户需执......
  • Postgresql集群搭建与PostGIS安装
    目录Postgresql集群搭建手册一、软件安装预先准备工作二、Postgresql安装(附带PostgreGIS安装)2.1potgresql安装2.2postgres常见错误说明三、PostgreGIS安装postGIS四.Postgresql数据库备份与恢复五.postgresSQL集群重启Postgresql集群搭建手册一、软件安装预先准备工作Linu......