分析函式學習3 ROW_NUMBER
ROW_NUMBER is an analytic function. It assigns a unique number to each row to which it is applied (either each row in the partition or each row returned by the query), in the ordered sequence of rows specified in the order_by_clause, beginning with 1.
You cannot use ROW_NUMBER or any other analytic function for expr. That is, you can use other built-in function expressions for expr, but you cannot nest analytic functions.
ROW_NUMBER() OVER( order_by_clause)query_partition_clause
Example
For each department in the sample table oe.employees, the following example assigns numbers to each row in order of employee's hire date:
SELECT department_id, last_name, employee_id, ROW_NUMBER()
OVER (PARTITION BY department_id ORDER BY employee_id) AS emp_id
FROM employees;
DEPARTMENT_ID LAST_NAME EMPLOYEE_ID EMP_ID
------------- ------------------------- ----------- ----------
10 Whalen 200 1
20 Hartstein 201 1
20 Goyal 202 2
30 Raphaely 114 1
30 Khoo 115 2
30 Baida 116 3
30 Tobias 117 4
30 Himuro 118 5
30 Colmenares 119 6
40 Marvis 203 1
.
.
.
100 Popp 113 6
110 Higgens 205 1
110 Gietz 206 2
ROW_NUMBER is a nondeterministic function. However, employee_id is a unique key, so the results of this application of the function are deterministic.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/219138/viewspace-913422/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Python學習-字串函式操作3Python字串函式
- 3. PHP 函式學習 strrpos ()PHP函式
- MySQL自定義變數實現row_number分析函式的天坑MySql變數函式
- 函式學習函式
- Python3學習(18)--偏函式(Partial)Python函式
- SQL Server中row_number函式的常見用法SQLServer函式
- spark RDD的學習,filter函式的學習,split函式的學習SparkFilter函式
- MySQL函式學習(一)-----字串函式MySql函式字串
- 函式學習五函式
- 函式學習二函式
- 函式學習四函式
- 函式學習六函式
- 函式學習三函式
- 函式的學習函式
- 學習Rust 函式Rust函式
- Python學習之函式Python函式
- 字串函式學習三字串函式
- 字串函式學習二字串函式
- 字串函式學習一字串函式
- TypeScript學習(二)—— 函式TypeScript函式
- MySQL中的ROW_NUMBER視窗函式簡單瞭解下MySql函式
- numpy學習回顧-數學函式及邏輯函式函式
- Java學習隨筆(函式式介面)Java函式
- async函式學習筆記。函式筆記
- 函式 - Go 學習記錄函式Go
- Python學習之zip函式Python函式
- Haskell學習-高階函式Haskell函式
- 學習Scala 方法與函式函式
- JS的學習理解--->函式JS函式
- 深度學習(啟用函式)深度學習函式
- 生成函式 學習筆記函式筆記
- go語言學習-函式Go函式
- 深度學習——loss函式的學習筆記深度學習函式筆記
- C#學習 數學函式(21)C#函式
- ROW_NUMBER 開窗函式最佳化方案(Oracle && PostgreSQL 效能比對)函式OracleSQL
- PHP 學習總結之函式PHP函式
- Python學習-字串函式操作1Python字串函式
- 函式 -- 就要學習 Go 語言函式Go
- Golang學習筆記-1.6 函式Golang筆記函式