求助 PostgreSQL 大神

2019-07-12 22:38:43 +08:00
 nuistzhou

有 2 个表: 需要查询表 1 的 date 字段得到日期数值,然后再去表 2 里找该日期数字对应的字段名,将找到的字段名对应的值 Join 回表一。感觉要用动态 SQL,求启发。
附上 2 个表的截图:
表 1:

表 2:

上面可能说得太抽象,看图说话,表 1 里的第 3 行数据,对应的 date 是 2018-10,那么就要去表二里筛选过的行里的‘ 2018-10 ’这一列,把对应的值 Join 回表 1 里。

4857 次点击
所在节点    PostgreSQL
13 条回复
micean
2019-07-12 23:00:37 +08:00
写成存储过程?
nuistzhou
2019-07-12 23:18:49 +08:00
@micean 嗯,但是不知道怎么写。。。
niubee1
2019-07-12 23:23:19 +08:00
超过标准 SQL 的纲了。干嘛老想着一条 SQL 打天下
c6h6benzene
2019-07-12 23:24:06 +08:00
图倒是都挂了…是要 201810 对应的列名?
nuistzhou
2019-07-13 00:16:17 +08:00
@c6h6benzene ‘ 2018-10 ’就会是列名,要把这个值 Join 回表 1。 这个问题的复杂性在于,每一个记录都可能对应表 2 里不同的列名,因为它取决于每个记录的 date 值。
reus
2019-07-13 00:59:40 +08:00
谁设计这个表的,真的应该开除
mengyaoss77
2019-07-13 01:05:37 +08:00
写个脚本列变行吧
widewing
2019-07-13 02:00:19 +08:00
crosstab 吧
c6h6benzene
2019-07-13 11:29:06 +08:00
@nuistzhou 后来看到图了。可能你放到 Excel 里面 HLOOKUP 会比较快。
beginor
2019-07-13 15:58:26 +08:00
表 1 crosstab 将日期行转列, 然后再和表 2 进行关联, 或者直接对表 2 进行 SQL 拼接进行嵌套查询, 应该都可以做到, 个人认为算是中等难度吧。
Aksura
2019-07-14 09:34:11 +08:00
@nuistzhou 表 2 这种在数据仓库里挺常见的,建议楼主先把表 2 做行列转换,使日期字段名变为一列值,再与表 1 JOIN。这个在 Oracle 里用 pivot/unpivot,PostgreSQL 里建议安装 tablefunc 这个 extension (服务端安装时自带的),用它的 crosstab 函数。
LeeSeoung
2019-07-14 09:48:05 +08:00
楼上正解。。关键就是行转列 列转行
CRVV
2019-07-17 00:15:40 +08:00
select table1.date, to_json(table2)->table1.date as v from table1 cross join table2 order by 1;

需要再处理一下 date 转成 TEXT 类型

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/582532

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX