SELECT * ,CUME_DIST( )OVER (PARTITION BY MyName ORDER BY Num) AS 'CUME_DIST' --相对(最大值)位置
,PERCENT_RANK( )OVER (PARTITION BY MyName ORDER BY Num) AS 'PERCENT_RANK' --相对排名,排名分数参考 CUME_DIST
,FIRST_VALUE (MyName)OVER ( ORDER BY Num ASC) AS 'FIRST_VALUE' --Num 最低的是哪个MyName
,LAST_VALUE (MyName)OVER ( ORDER BY Num ASC) AS 'LAST_VALUE' --Num 排序选底部的那个MyName
,LAG (Num,1,0)OVER (ORDER BY Num ASC) AS 'LAG' --上/下一行(或多行)的值移到下/上一行(或多行),方便对比
,LEAD (Num,1,0)OVER (ORDER BY Num ASC) AS 'LEAD' --与LAG一样,排序相反
,PERCENTILE_CONT(0.5)WITHIN GROUP (ORDER BY Num) OVER (PARTITION BY MyName) AS 'PERCENTILE_CONT' --连续分布计算百分位数
,PERCENTILE_DISC(0.5)WITHIN GROUP (ORDER BY Num) OVER (PARTITION BY MyName) AS 'PERCENTILE_DISC' --离散分布计算百分位数
FROM (VALUES('AA',55),('AA',30.5),('BB',55),('BB',99),('BB',0),('BB',55))AS T(MyName,Num)
ORDER BY Num ASC
/*
MyName Num CUME_DIST PERCENT_RANK FIRST_VALUE LAST_VALUE LAG LEAD PERCENTILE_CONT PERCENTILE_DISC
------ ----- --------- ------------ ----------- ---------- ----- ----- --------------- ---------------
BB 0.0 0.25 0 BB BB 0.0 30.5 55 55.0
AA 30.5 0.5 0 BB AA 0.0 55.0 42.75 30.5
AA 55.0 1 1 BB BB 30.5 55.0 42.75 30.5
BB 55.0 0.75 0.33333 BB BB 55.0 55.0 55 55.0
BB 55.0 0.75 0.33333 BB BB 55.0 99.0 55 55.0
BB 99.0 1 1 BB BB 55.0 0.0 55 55.0
*/