row_number()over()使用


語法:

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. [數] 分割;分隔;區分。讓我們再結合下面的參數說明和實例很容易就理解它的含義了。

 

參數:

PARTITION BY value_expression
         將 FROM 子句生成的結果集划入應用了 ROW_NUMBER 函數的分區。 value_expression 指定對結果集進行分區所依據的列。
    如果未指定 PARTITION BY,則此函數將查詢結果集的 所有行視為單個組。
order_by_clause
         ORDER BY 子句可確定在特定分區中為行分配唯一 ROW_NUMBER 的順序。
返回值類型:
bigint(長整型)

以上是對row_number()over()的理論了解,現在開始用例子演示:

先建表(dbo.PeopleInfo):

復制代碼
CREATE TABLE [dbo].[PeopleInfo]( [id] [int] IDENTITY(1,1) NOT NULL, [name] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL, [Gender] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL, [numb] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL, [phone] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL, [FenShu] [int] NULL ) ON [PRIMARY]
復制代碼

向表中插入數據:

insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('李歡','','3223','1365255',80) insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('李歡','','322123','1',90) insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('李名','','3213112352','13152',56) insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('李名','','32132312','13342563',60) insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('王華','','3223','1365255',80)

查詢出所有插入的數據:

select * from dbo.PeopleInfo

結果如圖:



例子:只用order by 不用 partition by 的sql語句如下:

--不用partition by select [name],gender,fenshu, row_number() over(order by fenshu desc) as num from dbo.PeopleInfo

結果如圖:

例子:用order by 也用 partition by 的sql語句如下:

select [name],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)知識點可以看看):

--查找出不同性別中分數最高的學生 with temp as ( select [name],gender,fenshu, row_number() over(partition by Gender order by fenshu desc) as num from dbo.PeopleInfo ) select * from temp where num = 1

結果如圖:

 

 

轉自:https://www.cnblogs.com/shuangnet/archive/2013/04/12/3016898.html

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM