PostgreSQL 中动态将行数据转换为列数据的替代方案:CASE
和 GROUP BY
vs. crosstab
函数
在 PostgreSQL 中,许多用户需要将行数据表转换为列数据表以进行分析和报告。虽然 CASE
和 GROUP BY
是常用的方法,但存在更动态和高效的替代方案。
问题陈述
例如,考虑以下表格:
id | feh | bar |
---|---|---|
1 | 10 | A |
2 | 20 | A |
3 | 3 | B |
4 | 4 | B |
5 | 5 | C |
6 | 6 | D |
7 | 7 | D |
8 | 8 | D |
期望的输出将此数据转换为以下格式:
bar | val1 | val2 | val3 |
---|---|---|---|
A | 10 | 20 | NULL |
B | 3 | 4 | NULL |
C | 5 | NULL | NULL |
D | 6 | 7 | 8 |
使用 CASE
和 GROUP BY
的解决方案
一种实现此目标的方法是使用 CASE
和 GROUP BY
技术:
SELECT bar, MAX(CASE WHEN abc."row" = 1 THEN feh ELSE NULL END) AS "val1", MAX(CASE WHEN abc."row" = 2 THEN feh ELSE NULL END) AS "val2", MAX(CASE WHEN abc."row" = 3 THEN feh ELSE NULL END) AS "val3" FROM ( SELECT bar, feh, row_number() OVER (partition by bar) as row FROM "Foo" ) abc GROUP BY bar
虽然此方法有效,但在灵活性和性能方面存在潜在的局限性。
crosstab
函数:一种动态解决方案
PostgreSQL 中 tablefunc
模块引入的 crosstab()
函数是一种更动态、更高效的替代方案。使用 crosstab()
函数,无需显式定义输出列即可实现所需的转换。
基本 crosstab
解决方案
对于示例问题,基本的 crosstab
解决方案如下:
SELECT * FROM crosstab( 'SELECT bar, 1 AS cat, feh FROM tbl_org ORDER BY bar, feh') AS ct (bar text, val1 int, val2 int, val3 int);
在此查询中,SELECT bar, 1 AS cat, feh
提供与 crosstab()
兼容的格式的数据。cat
列用作虚拟占位符,因为表中没有类别信息。
高级 crosstab
解决方案
如果存在实际的类别列,则可以使用它来控制结果中值的顺序。以下查询演示了这一点:
SELECT * FROM crosstab( $$ SELECT bar, val, feh FROM ( SELECT *, 'val' || row_number() OVER (PARTITION BY bar ORDER BY feh) AS val FROM tbl_org ) x ORDER BY 1, 2 $$ , $$VALUES ('val1'), ('val2'), ('val3')$$ ) AS ct (bar text, val1 int, val2 int, val3 int);
动态 crosstab
虽然上述解决方案提供了动态列生成,但在 PostgreSQL 中动态返回不同的列更具挑战性。但是,在某些限制下,可以使用 tablefunc
模块的内置功能来实现。
结论
crosstab()
函数为 CASE
和 GROUP BY
方法提供了一种强大而动态的替代方案。它允许灵活的数据转换,使其成为 PostgreSQL 中数据操作的宝贵工具。
以上是PostgreSQL中如何动态地将行数据转换为列数据?的详细内容。更多信息请关注PHP中文网其他相关文章!

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]

本文讨论了使用Drop Table语句在MySQL中放下表,并强调了预防措施和风险。它强调,没有备份,该动作是不可逆转的,详细介绍了恢复方法和潜在的生产环境危害。

本文讨论了在PostgreSQL,MySQL和MongoDB等各个数据库中的JSON列上创建索引,以增强查询性能。它解释了索引特定的JSON路径的语法和好处,并列出了支持的数据库系统。

文章讨论了使用准备好的语句,输入验证和强密码策略确保针对SQL注入和蛮力攻击的MySQL。(159个字符)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

禅工作室 13.0.1
功能强大的PHP集成开发环境

Atom编辑器mac版下载
最流行的的开源编辑器

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver Mac版
视觉化网页开发工具