DENSE_RANK (Transact-SQL)
傳回結果集資料分割內之資料列次序,次序中沒有任何間距。資料列次序是一個加上相關資料列前面之相異次序的數目。
語法
DENSE_RANK ( ) OVER ( [ < partition_by_clause > ] < order_by_clause > )
引數
< partition_by_clause>
將 FROM 子句所產生的結果集分成套用 DENSE_RANK 函數的資料分割。如需 PARTITION BY 語法,請參閱<OVER 子句 (Transact-SQL)>。< order_by_clause>
決定將 DENSE_RANK 值套用於資料分割中之資料列的順序。在用於次序函數的 <order_by_clause> 中,整數不能代表資料行。
傳回類型
bigint
備註
如果在相同資料分割中,針對某個次序聯結了兩個或更多資料列,每個聯結的資料列都會收到相同的次序。例如,如果兩位超級業務員有相同的 SalesYTD 值,他們的次序便都是第一。SalesYTD 次高的業務員之次序便是第二。這便是在這個資料列之前的相異資料列數加一。因此,DENSE_RANK 函數所傳回的數目不會有間距,次序一律是連續的。
整個查詢的排序順序決定了資料列在結果中的出現順序。這隱含次序第一的資料列,不一定是資料分割中的第一個資料列。
範例
下列範例會傳回不同位置之產品數量的 DENSE_RANK。請注意,OVER 子句中的 ORDER BY 會排列 DENSE_RANK 的順序,而 SELECT 陳述式的 ORDER BY 會排列結果集的順序。
USE AdventureWorks;
GO
SELECT i.ProductID, p.Name, i.LocationID, i.Quantity,
DENSE_RANK() OVER (PARTITION BY i.LocationID ORDER BY i.Quantity) AS DENSE_RANK
FROM Production.ProductInventory i
INNER JOIN Production.Product p
ON i.ProductID = p.ProductID
ORDER BY Name;
GO