oracle中pivot用法

PIVOT函数用于将一个表中的行转换为列。它可用于将一个具有多个相同值的列转换为多个列,每个列包含该值的一个实例。以下是使用PIVOT函数的一般语法:

SELECT *  
FROM (  
    SELECT column1, column2, ...  
    FROM table_name  
)  
PIVOT (  
    aggregation_function(column1)  
    FOR column2 IN (value1, value2, ...)  
)

其中:
aggregation_function 是要对数据进行聚合的函数,例如SUM、AVG、COUNT等。
column1 是打算聚合展示的列
column2 是要转换为列的列名。
value1, value2, … 是要转换为列的值。

WITH aa as	
(	
	SELECT k.mon,k.RESULT,k.con,round(k.con/(sum(k.con) over(PARTITION BY k.mon)),4)*100 ro	from 
	(
		SELECT substr(t.sos_id,1,4) mon,t.RESULT,count(t.sos_id) con FROM 	
		(	
			SELECT sdf.sos_id,sdf."RESULT" ,RANK() OVER(PARTITION BY sdf.APPLICATIONNO ORDER BY sdf.SOS_ID DESC ) rnk  FROM SOS_DA_FINALRESULT sdf 
			WHERE sdf.SOS_ID >'2301'
		) t
		WHERE t.rnk=1
		GROUP BY substr(t.sos_id,1,4),t.RESULT
	) k	
) 

SELECT * FROM (SELECT mon,RESULT,ro FROM  aa )
pivot(max(ro) FOR mon IN ('2301','2302','2303','2304','2305','2306','2307','2308','2309')) --ORDER BY RESULT

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值