pgsql 列转行操作记录

 现有如下的数据 需要统计三餐消费中哪一餐消费最高,思路是先进行列转行 再使用row_number() over()函数进行排名可以获取排名  再取pm=1的数据

 

 xh  zcxfje(早餐)  wcxfje(中餐) wacxfje(晚餐)
 1000  26975  126535 42310
 1001  3490  85200 36780

 语句实现如下:

with tmp_table as (
select xh, zczje as sczje,'早餐' as sclx from (
select xh,sum(zcxfje)as zczje,
sum(wcxfje)as wczje,sum(wacxfje)as waczje
from adm.edu_app_ykt_scxf
GROUP BY xh )as tab1
union all
select xh, wczje as sczje ,'午餐' as sclx from (
select xh,sum(zcxfje)as zczje,
sum(wcxfje)as wczje,sum(wacxfje)as waczje
from adm.edu_app_ykt_scxf
GROUP BY xh )as tab1
union all
select xh, waczje as sczje ,'晚餐' as sclx from (
select xh,sum(zcxfje)as zczje,
sum(wcxfje)as wczje,sum(wacxfje)as waczje
from adm.edu_app_ykt_scxf
GROUP BY xh )as tab1
)
select* from (select xh,row_number() over(partition by xh ORDER BY sczje desc ) as pm ,sczje,sclx
from tmp_table)as table1
where pm=1

先使用with 语句进行列转换成行 并补充三餐类型,再进行窗口排名函数即可得出结果。

暂时只想到该办法,有好的办法欢迎留言讨论。

posted @   Young_Mo  阅读(3408)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示