首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PostgreSQL去噪查询

PostgreSQL去噪查询
EN

Stack Overflow用户
提问于 2013-09-17 03:11:39
回答 1查看 122关注 0票数 0

我使用的是AWS红移,它使用PostgreSQL作为sql语言。在将数据还原为一行的查询中,我需要一些帮助。

我的图式

代码语言:javascript
复制
Milestone
  -ItemId
  -LocationType //mapped to enum X, Y, Z
  -EventTime

里程碑可以有三种类型的位置X,Y或Z。我想把这个变成一行。

代码语言:javascript
复制
ItemId EventTime_X EventTime_Y EventTime_Z

我曾经尝试过这样的方法,但这只是需要很长一段时间才能运行。

代码语言:javascript
复制
select x.itemId, X.eventTime as EventTime_X, Y.eventTime as EventTime_Y, z.eventTime as EventTime_Z
from (select * from milestone where LocationType = 'X') as X
left outer join (select * from milestone where LocationType = 'Y') as Y on x.itemId=y.itemId
left outer join (select * from milestone where LocationType = 'Z') as Z on x.itemId=z.itemId
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-09-17 03:16:51

假设X、Y和Z有一个里程碑,您可以使用条件聚合来完成这一任务:

代码语言:javascript
复制
select m.itemId,
       max(case when m.LocationType = 'X' then eventTime end) as eventTime_X,
       max(case when m.LocationType = 'Y' then eventTime end) as eventTime_Y,
       max(case when m.LocationType = 'Z' then eventTime end) as eventTime_Z
from Milestone m
where LocationType in ('X', 'Y', 'Z')
group by m.itemId;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18840717

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档