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