四、 使用RANK和DENSE_RANK处理同级问题
基于可选的partition子句和要求的order by子句,ROW_NUMBER函数默认地递增(加1)每一个返回结果的值。然而,有时你可能想以不同方式处理相同级别,而不是把相同的值赋给相同的级别。例如,前面显示的总订单列表中,Tito在2005年12月22日实现的订单数与Bruce在2006年1月5日实现的订单数相同;然而,ROW_NUMBER函数却把这两行评价为#4和#5,而不是都评价为#4。
RANK和DENSE_RANK函数都能够使用相同的评价计数级。例如,使用下列查询:
SELECT c.Name,o.DateOrdered,tab.TotalOrderAmount, RANK() OVER (ORDER BY TotalOrderAmount DESC) AS BestCustomerFROM vwTotalAmountBilledPerOrder AS tab INNER JOIN Orders AS o ON o.OrderID = tab.OrderID INNER JOIN Customers AS c ON c.CustomerID = o.CustomerID |
这个语句将返回如下表所示的结果:
Name | DateOrdered | TotalOrderAmount | BestCustomer | Bob | 12/1/2005 | 12649.9900 | 1 | Darren | 1/2/2006 | 620.0000 | 2 | Bob | 12/19/2005 | 265.8500 | 3 | Tito | 12/22/2005 | 14.9500 | 4 | Bruce | 1/5/2006 | 14.9500 | 5 | Tito | 12/18/2005 | 12.4400 | 6 | Bruce | 1/4/2006 | 9.9900 | 7 | Lee Ann | 1/3/2006 | 8.5000 | 8 | ... |
注意,具有相同数量的两个订单是怎样都被评价为#4的。RANK和DENSE_RANK之间的不同之处在于,在平级的结果后他们是如何重新开始计数的。RANK绕过尽可能多的平级的结果。在我们上面的示例中,因为有两个结果绑定在#4上,因此跟随其后的#5被跳过而评价等级以#6继续。另一方面,DENSE_RANK从下一个整数继续。如果我们在上面的查询中使用函数名DENSE_RANK代替RANK,那么Tito在2005年12月18日相应于单价$12.44的订单评价将是#5。
类似于ROW_NUMBER函数,RANK和DENSE_RANK函数都能使用可选的PARTITION BY语句。
五、 使用NTILE函数对评价结果进行分组
SQL Server 2005新引入的最后一个与T-SQL函数相关的评价函数是NTILE(int)。NTILE象其它的评价函数一样操作,但是它能够把结果分成组,每组中相应相同评价结果的记录。你可以使用NTILE函数把结果分解成两组、三组或四组等,如下例所示:
SELECT ProductID,Name,Price,NTILE(4) OVER (ORDER BY Price DESC) as QuartileFROM Produts |
这个语句将返回如下表所示的结果:
ProductID | Name | Price | Quartile | 8 | Desk | 495.0000 | 1 | 10 | Executive Chair | 295.0000 | 1 | 9 | Chair | 125.0000 | 2 | 5 | Mouse | 14.9500 | 2 | 6 | Mousepad | 9.9900 | 3 | 11 | Scissors | 8.5000 | 3 | 4 | Stapler | 7.9500 | 4 | 3 | Binder | 1.9500 | 4 |
在随本文下载的演示程序中,我提供了一个例子,它使用了一个具有NTILE函数的视图来允许用户有选择地查看各种分组的最大订单量。
六、 结论
在本文中,我们探讨了SQL Server 2005中的四个新函数的用法。这四个新函数分别是:ROW_NUMBER,RANK,DENSE_RANK和NTILE。与SQL Server 2000使用的旧技术相比,它们使得返回评价结果更为容易。然而,这些函数仅仅是SQL Server 2005中所提供的新的T-SQL特征中的极少的一部分。 
2/2 首页 上一页 1 2 |