Books Online对CUME_DIST()的描述:
计算某个值在 SQL Server 2012 中的一组值内的累积分布。
也即,CUME_DIST 计算某指定值在一组值中的相对位置。
对于行 r,假定采用升序,r 的 CUME_DIST 是值低于或等于 r 的值的行数除以在分区或查询结果集中求出的行数。
CUME_DIST 类似于 PERCENT_RANK 函数。
注意此处的描述:对于行 r,假定采用升序,r 的 CUME_DIST 是值低于或等于 r 的值的行数除以在分区或查询结果集中求出的行数。
这句话说明了求得此函数的值的方法。
Example:
USE AdventureWorks2012
GO
SELECT SalesOrderID, OrderQty,
CUME_DIST() OVER(ORDER BY SalesOrderID) AS CDist
FROM Sales.SalesOrderDetail
WHERE SalesOrderID IN (43670, 43669, 43667, 43663)
ORDER BY CDist DESC
GO
GO
SELECT SalesOrderID, OrderQty,
CUME_DIST() OVER(ORDER BY SalesOrderID) AS CDist
FROM Sales.SalesOrderDetail
WHERE SalesOrderID IN (43670, 43669, 43667, 43663)
ORDER BY CDist DESC
GO
result:
此处,over()中没有partition by,因此整个数据集做为一个窗口,所以此窗口包涵全部10条记录。因此:
查询结果集中求出的行数=10
对于salesOrderID=43670,小于等于salesOrderID为43670的有10条记录,因此 CDIST=10/10=1
对于salesOrderID=43669,小于等于salesOrderID为43669的有6条记录,因此 CDIST=6/10=0.6
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/101629/viewspace-748557/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/101629/viewspace-748557/