ROW_NUMBER (Transact-SQL)ROW_NUMBER (Transact-SQL)

GILT FÜR: jaSQL Server jaAzure SQL-DatenbankjaAzure SQL Data Warehouse jaParallel Data WarehouseAPPLIES TO: yesSQL Server yesAzure SQL Database yesAzure SQL Data Warehouse yesParallel Data Warehouse

Nummeriert die Ausgabe eines Resultsets.Numbers the output of a result set. Genauer gesagt wird die fortlaufende Nummer einer Zeile innerhalb einer Partition eines Resultsets zurückgegeben, beginnend mit 1 für die erste Zeile in jeder Partition.More specifically, returns the sequential number of a row within a partition of a result set, starting at 1 for the first row in each partition.

ROW_NUMBER und RANK sind ähnlich.ROW_NUMBER and RANK are similar. ROW_NUMBER nummeriert alle Zeilen sequenziell (z.B. 1, 2, 3, 4, 5).ROW_NUMBER numbers all rows sequentially (for example 1, 2, 3, 4, 5). RANK stellt den gleichen numerischen Wert für gleichwertige Werte bereit (z.B. 1, 2, 3, 4, 5).RANK provides the same numeric value for ties (for example 1, 2, 2, 4, 5).

Hinweis

ROW_NUMBER ist ein temporärer Wert, der berechnet wird, wenn die Abfrage ausgeführt wird.ROW_NUMBER is a temporary value calculated when the query is run. Unter IDENTITY-Eigenschaft und SEQUENCE finden Sie weitere Informationen zum dauerhaften Speichern von Zahlen in einer Tabelle.To persist numbers in a table, see IDENTITY Property and SEQUENCE.

Themenlinksymbol Transact-SQL-SyntaxkonventionenTopic link icon Transact-SQL Syntax Conventions

SyntaxSyntax

ROW_NUMBER ( )   
    OVER ( [ PARTITION BY value_expression , ... [ n ] ] order_by_clause )  

ArgumenteArguments

PARTITION BY value_expressionPARTITION BY value_expression
Teilt das von der FROM-Klausel erzeugte Resultset in Partitionen, auf die die ROW_NUMBER-Funktion angewendet wird.Divides the result set produced by the FROM clause into partitions to which the ROW_NUMBER function is applied. value_expression gibt die Spalte an, nach der das Resultset partitioniert wird.value_expression specifies the column by which the result set is partitioned. Wird PARTITION BY nicht angegeben, verarbeitet die Funktion alle Zeilen des Abfrageresultsets als einzelne Gruppe.If PARTITION BY is not specified, the function treats all rows of the query result set as a single group. Weitere Informationen finden Sie unter OVER-Klausel (Transact-SQL).For more information, see OVER Clause (Transact-SQL).

order_by_clauseorder_by_clause
Die ORDER BY-Klausel bestimmt die Reihenfolge, in der den Zeilen die eindeutige ROW_NUMBER innerhalb einer angegebenen Partition zugewiesen wird.The ORDER BY clause determines the sequence in which the rows are assigned their unique ROW_NUMBER within a specified partition. Sie ist erforderlich.It is required. Weitere Informationen finden Sie unter OVER-Klausel (Transact-SQL).For more information, see OVER Clause (Transact-SQL).

RückgabetypenReturn Types

bigintbigint

Allgemeine HinweiseGeneral Remarks

Es gibt keine Garantie, dass die mithilfe von ROW_NUMBER() zurückgegebenen Zeilen bei jeder Ausführung exakt gleich sind, es sei denn, die folgenden Bedingungen treffen zu.There is no guarantee that the rows returned by a query using ROW_NUMBER() will be ordered exactly the same with each execution unless the following conditions are true.

  1. Werte der partitionierten Spalte sind eindeutig.Values of the partitioned column are unique.

  2. Werte der ORDER BY-Spalten sind eindeutig.Values of the ORDER BY columns are unique.

  3. Kombinationen der Werte der Partitionsspalte und ORDER BY-Spalten sind eindeutig.Combinations of values of the partition column and ORDER BY columns are unique.

ROW_NUMBER() ist nicht deterministisch.ROW_NUMBER() is nondeterministic. Weitere Informationen finden Sie unter Deterministic and Nondeterministic Functions.For more information, see Deterministic and Nondeterministic Functions.

BeispieleExamples

A.A. Einfache BeispieleSimple examples

Die folgende Abfrage gibt vier Systemtabellen in alphabetischer Reihenfolge zurück.The following query returns the four system tables in alphabetic order.

SELECT 
  name, recovery_model_desc
FROM sys.databases 
WHERE database_id < 5
ORDER BY name ASC;

Im Folgenden finden Sie das Resultset.Here is the result set.

NAMEname recovery_model_descrecovery_model_desc
mastermaster SIMPLESIMPLE
modelmodel FULLFULL
msdbmsdb SIMPLESIMPLE
tempdbtempdb SIMPLESIMPLE

Fügen Sie mit der ROW_NUMBER-Funktion eine Spalte namens Row# (in diesem Fall) hinzu, um eine Spalte für Zeilennummern vor jeder Zeile hinzuzufügen.To add a row number column in front of each row, add a column with the ROW_NUMBER function, in this case named Row#. Sie müssen die ORDER BY-Klausel bis zur OVER-Klausel verschieben.You must move the ORDER BY clause up to the OVER clause.

SELECT 
  ROW_NUMBER() OVER(ORDER BY name ASC) AS Row#,
  name, recovery_model_desc
FROM sys.databases 
WHERE database_id < 5;

Im Folgenden finden Sie das Resultset.Here is the result set.

Row#Row# NAMEname recovery_model_descrecovery_model_desc
11 mastermaster SIMPLESIMPLE
22 modelmodel FULLFULL
33 msdbmsdb SIMPLESIMPLE
44 tempdbtempdb SIMPLESIMPLE

Durch das Hinzufügen einer PARTITION BY-Klausel zur recovery_model_desc-Spalte wird die Nummerierung neu gestartet, wenn der recovery_model_desc-Wert sich verändert.Adding a PARTITION BY clause on the recovery_model_desc column, will restart the numbering when the recovery_model_desc value changes.

SELECT 
  ROW_NUMBER() OVER(PARTITION BY recovery_model_desc ORDER BY name ASC) 
    AS Row#,
  name, recovery_model_desc
FROM sys.databases WHERE database_id < 5;

Im Folgenden finden Sie das Resultset.Here is the result set.

Row#Row# NAMEname recovery_model_descrecovery_model_desc
11 modelmodel FULLFULL
11 mastermaster SIMPLESIMPLE
22 msdbmsdb SIMPLESIMPLE
33 tempdbtempdb SIMPLESIMPLE

B.B. Zurückgeben der Zeilennummer für VertriebsmitarbeiterReturning the row number for salespeople

Im folgenden Beispiel wird eine Zeilennummer für die Vertriebsmitarbeiter in Adventure Works CyclesAdventure Works Cycles auf Grundlage der Verkaufszahlen des laufenden Jahres berechnet.The following example calculates a row number for the salespeople in Adventure Works CyclesAdventure Works Cycles based on their year-to-date sales ranking.

USE AdventureWorks2012;   
GO  
SELECT ROW_NUMBER() OVER(ORDER BY SalesYTD DESC) AS Row,   
    FirstName, LastName, ROUND(SalesYTD,2,1) AS "Sales YTD"   
FROM Sales.vSalesPerson  
WHERE TerritoryName IS NOT NULL AND SalesYTD <> 0;  

Im Folgenden finden Sie das Resultset.Here is the result set.

  
Row FirstName    LastName               SalesYTD  
--- -----------  ---------------------- -----------------  
1   Linda        Mitchell               4251368.54  
2   Jae          Pak                    4116871.22  
3   Michael      Blythe                 3763178.17  
4   Jillian      Carson                 3189418.36  
5   Ranjit       Varkey Chudukatil      3121616.32  
6   José         Saraiva                2604540.71  
7   Shu          Ito                    2458535.61  
8   Tsvi         Reiter                 2315185.61  
9   Rachel       Valdez                 1827066.71  
10  Tete         Mensa-Annan            1576562.19  
11  David        Campbell               1573012.93  
12  Garrett      Vargas                 1453719.46  
13  Lynn         Tsoflias               1421810.92  
14  Pamela       Ansman-Wolfe           1352577.13  

C.C. Zurückgeben einer Teilmenge von ZeilenReturning a subset of rows

Im folgenden Beispiel werden Zeilennummern für alle Zeilen in der SalesOrderHeader-Tabelle in der Reihenfolge des OrderDate berechnet und nur die Zeilen 50 bis 60 (einschließlich) zurückgegeben.The following example calculates row numbers for all rows in the SalesOrderHeader table in the order of the OrderDate and returns only rows 50 to 60 inclusive.

USE AdventureWorks2012;  
GO  
WITH OrderedOrders AS  
(  
    SELECT SalesOrderID, OrderDate,  
    ROW_NUMBER() OVER (ORDER BY OrderDate) AS RowNumber  
    FROM Sales.SalesOrderHeader   
)   
SELECT SalesOrderID, OrderDate, RowNumber    
FROM OrderedOrders   
WHERE RowNumber BETWEEN 50 AND 60;  

D.D. Verwenden von ROW_NUMBER () mit PARTITIONUsing ROW_NUMBER() with PARTITION

Im folgenden Beispiel wird das Argument PARTITION BY zum Partitionieren des Abfrageresultset nach der Spalte TerritoryName verwendet.The following example uses the PARTITION BY argument to partition the query result set by the column TerritoryName. Durch die ORDER BY-Klausel in der OVER-Klausel werden die Zeilen in jeder Partition nach der Spalte SalesYTD sortiert.The ORDER BY clause specified in the OVER clause orders the rows in each partition by the column SalesYTD. Die ORDER BY-Klausel in der SELECT-Anweisung sortiert das gesamte Abfrageresultset nach TerritoryName.The ORDER BY clause in the SELECT statement orders the entire query result set by TerritoryName.

USE AdventureWorks2012;  
GO  
SELECT FirstName, LastName, TerritoryName, ROUND(SalesYTD,2,1) AS SalesYTD,  
ROW_NUMBER() OVER(PARTITION BY TerritoryName ORDER BY SalesYTD DESC) 
  AS Row  
FROM Sales.vSalesPerson  
WHERE TerritoryName IS NOT NULL AND SalesYTD <> 0  
ORDER BY TerritoryName;  

Im Folgenden finden Sie das Resultset.Here is the result set.

  
FirstName  LastName             TerritoryName        SalesYTD      Row  
---------  -------------------- ------------------   ------------  ---  
Lynn       Tsoflias             Australia            1421810.92    1  
José       Saraiva              Canada               2604540.71    1  
Garrett    Vargas               Canada               1453719.46    2  
Jillian    Carson               Central              3189418.36    1  
Ranjit     Varkey Chudukatil    France               3121616.32    1  
Rachel     Valdez               Germany              1827066.71    1  
Michael    Blythe               Northeast            3763178.17    1  
Tete       Mensa-Annan          Northwest            1576562.19    1  
David      Campbell             Northwest            1573012.93    2  
Pamela     Ansman-Wolfe         Northwest            1352577.13    3  
Tsvi       Reiter               Southeast            2315185.61    1  
Linda      Mitchell             Southwest            4251368.54    1  
Shu        Ito                  Southwest            2458535.61    2  
Jae        Pak                  United Kingdom       4116871.22    1  

Beispiele: Azure SQL Data WarehouseAzure SQL Data Warehouse und Parallel Data WarehouseParallel Data Warehouse.Examples: Azure SQL Data WarehouseAzure SQL Data Warehouse and Parallel Data WarehouseParallel Data Warehouse

E.E. Zurückgeben der Zeilennummer für VertriebsmitarbeiterReturning the row number for salespeople

Im folgenden Beispiel wird ROW_NUMBER für die Vertriebsmitarbeiter (basierend auf der zugewiesenen Sollvorgabe für den Verkauf) zurückgegeben.The following example returns the ROW_NUMBER for sales representatives based on their assigned sales quota.

-- Uses AdventureWorks  
  
SELECT ROW_NUMBER() OVER(ORDER BY SUM(SalesAmountQuota) DESC) 
    AS RowNumber,  
    FirstName, LastName,   
    CONVERT(varchar(13), SUM(SalesAmountQuota),1) AS SalesQuota   
FROM dbo.DimEmployee AS e  
INNER JOIN dbo.FactSalesQuota AS sq  
    ON e.EmployeeKey = sq.EmployeeKey  
WHERE e.SalesPersonFlag = 1  
GROUP BY LastName, FirstName;  

Dies ist ein Auszug aus dem Resultset.Here is a partial result set.


RowNumber  FirstName  LastName            SalesQuota  
---------  ---------  ------------------  -------------  
1          Jillian    Carson              12,198,000.00  
2          Linda      Mitchell            11,786,000.00  
3          Michael    Blythe              11,162,000.00  
4          Jae        Pak                 10,514,000.00  

F.F. Verwenden von ROW_NUMBER () mit PARTITIONUsing ROW_NUMBER() with PARTITION

Im folgenden Beispiel wird die Verwendung der ROW_NUMBER-Funktion mit dem PARTITION BY-Argument dargestellt.The following example shows using the ROW_NUMBER function with the PARTITION BY argument. Dadurch nummeriert die ROW_NUMBER-Funktion die Zeilen in jeder Partition.This causes the ROW_NUMBER function to number the rows in each partition.

-- Uses AdventureWorks  
  
SELECT ROW_NUMBER() OVER(PARTITION BY SalesTerritoryKey 
        ORDER BY SUM(SalesAmountQuota) DESC) AS RowNumber,  
    LastName, SalesTerritoryKey AS Territory,  
    CONVERT(varchar(13), SUM(SalesAmountQuota),1) AS SalesQuota   
FROM dbo.DimEmployee AS e  
INNER JOIN dbo.FactSalesQuota AS sq  
    ON e.EmployeeKey = sq.EmployeeKey  
WHERE e.SalesPersonFlag = 1  
GROUP BY LastName, FirstName, SalesTerritoryKey;  

Dies ist ein Auszug aus dem Resultset.Here is a partial result set.

 
RowNumber  LastName            Territory  SalesQuota  
---------  ------------------  ---------  -------------  
1          Campbell            1           4,025,000.00  
2          Ansman-Wolfe        1           3,551,000.00  
3          Mensa-Annan         1           2,275,000.00  
1          Blythe              2          11,162,000.00  
1          Carson              3          12,198,000.00  
1          Mitchell            4          11,786,000.00  
2          Ito                 4           7,804,000.00  

Weitere InformationenSee Also

RANK (Transact-SQL) RANK (Transact-SQL)
DENSE_RANK (Transact-SQL) DENSE_RANK (Transact-SQL)
NTILE (Transact-SQL)NTILE (Transact-SQL)