SQL 關于row_number()over() 今天用到了row_number()over(),現在就以知識點的形式總結一下,以便于以后的回顧。 ------------------- 參考資料MSDN ------------------- 語法: ROW_NUMBER ( )OVER ( [ PARTITION BY value_expression , ... [ n ] ] order_
SQL 關于row_number()over()
今天用到了row_number()over(),網站空間,現在就以知識點的形式總結一下,以便于以后的回顧。
-------------------參考資料MSDN-------------------
語法:
ROW_NUMBER ( ) OVER ( [ PARTITION BY value_expression , ... [ n ] ] order_by_clause )
通過語法可以看出 over里有兩個參數, partition by 和 order by ,網站空間,其中partition by是可以不寫的,但是order by是必須有的。可能對order by 比較熟悉(就是按什么排序),但 partition by是什么意思呢?partition 的中文解釋是:n. 劃分,分開;[數] 分割;隔墻;隔離物 vt. [數] 分割;分隔;區分。讓我們再結合下面的參數說明和實例很容易就理解它的含義了。
參數:
返回值類型:bigint(長整型)
以上是對row_number()over()的理論了解,現在開始用例子演示:
先建表(dbo.PeopleInfo):
.( (1,1) NOT NULL, (10) COLLATE Chinese_PRC_CI_AS NULL, (10) COLLATE Chinese_PRC_CI_AS NULL, (10) COLLATE Chinese_PRC_CI_AS NULL, (10) COLLATE Chinese_PRC_CI_AS NULL, )
向表中插入數據:
,Gender,numb,phone,fenshu) ,,,,80) ,Gender,numb,phone,fenshu) ,,,,90) ,Gender,numb,phone,fenshu) ,,,,56) ,Gender,numb,phone,fenshu) ,,,,60) ,Gender,numb,phone,fenshu) ,,,,80)
查詢出所有插入的數據:
dbo.PeopleInfo
結果如圖:
例子一:只用order by 不用 partition by 的sql語句如下:
,gender,fenshu, row_number() over(order by fenshu desc) as num from dbo.PeopleInfo
結果如圖:
例子二:用order by 也用 partition by 的sql語句如下:
,gender,fenshu, row_number() over(partition by Gender order by fenshu desc) as num from dbo.PeopleInfo
結果如圖:
比較例子一和例子二的結果圖很容易就明白partition by的用處了,以例子二為例就是先用partition by把性別【Gender】分成兩個區一個男一個女,虛擬主機,然后再用order by 把每個區里的分數【fenshu】從大到小排序。
-----------------------------------------------
練習題(用到了前面所講的cte(with。。as)知識點可以看看):
( ,gender,fenshu, row_number() over(partition by Gender order by fenshu desc) as num from dbo.PeopleInfo ) num = 1
結果如圖:
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com