久久天堂一区二区三区_国内精品久久久久影院网站_亚洲国产一区二区三区最新_亚洲国产一区二区三区四区五区

北京北大青鳥指導:SQL2005中新增函數的用法


SQL server 2005新增的幾個函數,分別是row_number( )、rank( )、,DENSE_RANK( )、ntile( )下面,北京北大青鳥通州校區ACCP學術部老師就以實例分別簡單講解。

1.row_number()
先來點數據,先建個表

SET NOCOUNT ON
CREATE TABLE Person(
FirstName VARCHAR(10),
Age INT,
Gender CHAR(1))
INSERT INTO Person VALUES ('Ted',23,'M')
INSERT INTO Person VALUES ('John',40,'M')
INSERT INTO Person VALUES ('George',6,'M')
INSERT INTO Person VALUES ('Mary',11,'F')
INSERT INTO Person VALUES ('Sam',17,'M')
INSERT INTO Person VALUES ('Doris',6,'F')
INSERT INTO Person VALUES ('Frank',38,'M')
INSERT INTO Person VALUES ('Larry',5,'M')
INSERT INTO Person VALUES ('Sue',29,'F')
INSERT INTO Person VALUES ('Sherry',11,'F')
INSERT INTO Person VALUES ('Marty',23,'F')直接用例子說明問題:SELECT ROW_NUMBER() OVER (ORDER BY Age) AS [Row Number by Age],
FirstName,
Age
FROM Person
出現的數據如下
Row Number by Age                FirstName            Age
--------------------------                 ----------            --------
1                                                Larry                   5
2                                                Doris                   6
3                                                George               6
4                                                Mary                   11
5                                                Sherry                 11
6                                                Sam                    17
7                                                Ted                     23
8                                                Marty                   23
9                                                Sue                     29
10                                              Frank                  38
11                                              John                    40可以觀察到,是根據年齡升序排列了,并且row_number()是給出了序列號了,這個序列號被重命名為Row Number by Age,與sql server2000對比:
如果在sql server2000中實現相對麻煩一些,我們可以利用IDENTITY()函數實現,但IDENTITY()函數只能用在sql server2000臨時表中,因此需要將數據檢索到臨時表里。
select identity(int,1,1) as [Row Number by Age],FirstName,Age into #A from Person order by Age
select * from #A
drop table #a如果不想按年齡排序,可以這樣寫
SELECT ROW_NUMBER() OVER (ORDER BY (SELECT 1)) AS [Row Number by Record Set], FirstName,Age FROM Person另外一個例子
SELECT ROW_NUMBER() OVER (PARTITION BY Gender ORDER BY Age) AS [Partition by Gender], FirstName,Age,GenderFROM Person這里是按性別劃分區間了,同一性別再按年齡來排序,輸出結果如下
Partition by Gender        FirstName        Age               Gender -------------------- ---------- ----------- ------ 1                          Doris            6                 F 2                          Mary             11                F 3                          Sherry           11                F 4                          Sue              29                F 1                          Larry            5                 M 2                          George           6                 M 3                          Sam              17                M 4                          Ted              23                M 5                          Marty            23                M 6                          Frank            38                M 7                          John             40                M注意,姓名M開始,序號又從1,2,3開始了

2.RANK( )函數
先看例子
SELECT RANK() OVER (ORDER BY Age) AS [Rank by Age], FirstName,Age FROM Person輸出如下:
Rank by Age                FirstName        Age -------------------- ---------- ----------- 1                          Larry            5 2                          Doris            6 2                          George           6 4                          Mary             11 4                          Sherry           11 6                          Sam              17 7                          Ted              23 7                          Marty            23 9                          Sue              29 10                         Frank            38 11                         John             40看到了么,同年嶺的話,將有相同的順序,順序成1,2,2,4了。與sql server2000對比:
出現了RANK()函數實在是方便,在sql server2000里實現排序并列的問題麻煩很多。
select [Rank by Age]=isnull((select count(*) from person where Age>A.Age),0)+1,FirstName,Age from Person A order by [Rank by Age]SELECT RANK() OVER(PARTITION BY Gender ORDER BY Age) AS [Partition by Gender],
FirstName, Age, Gender FROM Person輸出為Partition by Gender        FirstName        Age               Gender-------------------- ---------- ----------- ------ 1                          Doris            6                 F 2                          Mary             11                F 2                          Sherry           11                F 4                          Sue              29                F 1                          Larry            5                 M 2                          George           6                 M 3                          Sam              17                M 4                          Ted              23                M 4                          Marty            23                M 6                          Frank            38                M 7                          John             40                M
可以看到,按性別分組了,每個性別分組里,繼續是用了rank( )函數

3.DENSE_RANK( )函數
         SELECT DENSE_RANK() OVER (ORDER BY Age) AS [Dense Rank by Age],
         FirstName,
         Age
         FROM Person

輸出結果為:
Dense Rank by Age          FirstName        Age
-------------------- ---------- -----------
1                          Larry            5
2                          Doris            6
2                          George           6
3                          Mary             11
3                          Sherry           11
4                          Sam              17
5                          Ted              23
5                          Marty            23
6                          Sue              29
7                          Frank            38
8                          John             40

看到了么,和rank函數區別是,順序始終是連續的,Doris 和George同年,都是排第2位,但之后的mary不象rank函數那樣排第4,而是排第3位了


4.ntile( )函數
SELECT FirstName,
Age,
NTILE(3) OVER (ORDER BY Age) AS [Age Groups]
FROM Person

輸出結果:
FirstName        Age               Age Groups
---------- ----------- --------------------
Larry                5                  1
Doris                6                  1
George            6                  1
Mary                11                1
Sherry             11                 2
Sam                17                 2
Ted                 23                 2
Marty              23                 2
Sue                29                 3
Frank             38                 3
John               40                 3
這個函數按照ntile(n)中的N,把記錄強制分成多少段,11條記錄現在分成3段了,lary到mary是第1段,sherry到maty是第2段,sue到john是第3段了。

北大青鳥網上報名
北大青鳥招生簡章
久久天堂一区二区三区_国内精品久久久久影院网站_亚洲国产一区二区三区最新_亚洲国产一区二区三区四区五区

      9000px;">

          99国产精品国产精品久久| 精品卡一卡二卡三卡四在线| 欧美大片一区二区三区| 亚洲午夜久久久久久久久电影院| 91国偷自产一区二区开放时间| 亚洲精品免费看| 日韩亚洲欧美成人一区| 国产精品综合一区二区| 欧美国产禁国产网站cc| 日本韩国欧美一区| 蜜臀av亚洲一区中文字幕| 日韩欧美激情在线| 成人黄色av电影| 青草国产精品久久久久久| 亚洲国产精品精华液ab| 91精品国产综合久久久蜜臀图片| 成人免费视频免费观看| 秋霞影院一区二区| 亚洲一区二区三区美女| 久久精品视频一区二区| 欧美日韩电影在线播放| 成人污视频在线观看| 亚洲无人区一区| 国产精品美女视频| 日韩欧美国产午夜精品| 欧洲视频一区二区| av亚洲精华国产精华| 国产在线精品国自产拍免费| 午夜精品在线看| 一区二区三区免费网站| 欧美国产日产图区| 欧美www视频| 日韩一区二区免费视频| 色一区在线观看| 成人国产免费视频| 国产不卡视频一区二区三区| 麻豆国产欧美日韩综合精品二区| 亚洲福利一区二区| 亚洲精品国产精华液| 国产精品美日韩| 国产精品婷婷午夜在线观看| 久久综合久久99| 精品国产伦一区二区三区免费| 69成人精品免费视频| 欧美高清视频在线高清观看mv色露露十八| 91香蕉国产在线观看软件| av电影一区二区| 91丝袜美腿高跟国产极品老师| 大胆欧美人体老妇| 成人看片黄a免费看在线| 丁香另类激情小说| av电影一区二区| 91成人看片片| 欧美精品在线一区二区| 欧美一区二区三区在线视频| 欧美一区二区三区视频免费播放| 欧美一级欧美一级在线播放| 欧美一区二区三区系列电影| 日韩欧美高清dvd碟片| 欧美一级精品大片| 精品国产乱码久久久久久免费| 久久影音资源网| 成人免费在线观看入口| 亚洲影视在线播放| 美腿丝袜亚洲综合| 国产一区福利在线| 成人h版在线观看| 欧美网站一区二区| 欧美成人高清电影在线| 中文久久乱码一区二区| 亚洲宅男天堂在线观看无病毒| 亚洲成人av电影在线| 美女脱光内衣内裤视频久久网站| 国产成人在线色| 欧美另类变人与禽xxxxx| 精品国产自在久精品国产| 国产精品国产馆在线真实露脸| 亚洲一区二区视频| 国精品**一区二区三区在线蜜桃| 波多野结衣在线一区| 精品视频在线视频| 国产欧美一区二区精品久导航 | 国产乱码精品一区二区三| 国产成人av影院| 欧美日韩一卡二卡| 亚洲国产精品成人综合| 亚洲444eee在线观看| 国产成人综合视频| 欧美精品一二三区| 成人免费在线播放视频| 久久丁香综合五月国产三级网站 | 欧美v亚洲v综合ⅴ国产v| 日韩毛片在线免费观看| 久久99精品国产麻豆婷婷| 色综合久久88色综合天天6| 欧美xxxxx裸体时装秀| 亚洲国产精品一区二区尤物区| 国产精品99久| 日韩免费视频一区二区| 亚洲一区影音先锋| 一本一道久久a久久精品| 久久久精品国产免大香伊| 婷婷久久综合九色国产成人| 91看片淫黄大片一级| 欧美激情一区二区三区四区| 日韩电影一区二区三区四区| 色狠狠桃花综合| 中文字幕一区二区三区色视频| 韩国一区二区在线观看| 337p亚洲精品色噜噜狠狠| 亚洲国产精品久久人人爱蜜臀 | 一区二区三区四区激情| 成人午夜大片免费观看| 国产亚洲欧美中文| 国产又粗又猛又爽又黄91精品| 日韩一区二区免费视频| 日本系列欧美系列| 欧美一区二区观看视频| 香港成人在线视频| 欧美精品在欧美一区二区少妇| 一级特黄大欧美久久久| 色婷婷综合久久久久中文| 亚洲日本在线观看| 色激情天天射综合网| 亚洲精品水蜜桃| 色偷偷成人一区二区三区91| 国产精品传媒在线| 99精品视频一区| 一区二区三区免费网站| 欧美日韩国产首页| 日本网站在线观看一区二区三区 | 国产最新精品免费| 久久影视一区二区| 成人国产免费视频| 亚洲欧美日韩国产综合在线| 日本伦理一区二区| 亚洲3atv精品一区二区三区| 欧美一区二区三区公司| 精品亚洲国产成人av制服丝袜| 精品国产髙清在线看国产毛片| 国产精品资源在线观看| 中文字幕日韩精品一区| 欧美三级欧美一级| 精一区二区三区| 国产精品乱人伦中文| 欧美日韩国产大片| 国产美女一区二区三区| 最新成人av在线| 在线播放日韩导航| 成人黄色av电影| 视频在线观看国产精品| 久久久久久电影| 在线观看亚洲精品| 久久电影网电视剧免费观看| 中文字幕一区二区三区在线播放| 欧美日韩精品一区二区三区四区| 国产在线视频精品一区| 亚洲精品国产视频| 久久精品人人做人人爽97| 在线这里只有精品| 国产精品自拍三区| 亚洲福利一二三区| 日本一区二区成人在线| 这里只有精品免费| 99精品视频在线播放观看| 久久99久久99小草精品免视看| 国产精品国产三级国产a| 日韩午夜小视频| 在线国产亚洲欧美| a在线欧美一区| 国产精品一二三四区| 亚洲大尺度视频在线观看| 国产欧美日韩视频在线观看| 69堂成人精品免费视频| 一本久久综合亚洲鲁鲁五月天 | 欧美亚洲自拍偷拍| 粉嫩蜜臀av国产精品网站| 蜜桃久久久久久| 五月婷婷综合网| 亚洲精品午夜久久久| 国产视频一区在线播放| 91精品中文字幕一区二区三区| 色婷婷亚洲综合| 91同城在线观看| 99久久精品情趣| 高清成人免费视频| 国产精品一区二区x88av| 久久精品久久99精品久久| 五月婷婷激情综合| 丝袜美腿亚洲一区二区图片| 一区二区三区在线视频播放 | 国产精品麻豆网站| 久久亚洲综合av| 久久综合成人精品亚洲另类欧美 | 国产精品一区二区三区乱码| 五月天久久比比资源色| 亚洲国产wwwccc36天堂| 亚洲午夜久久久久中文字幕久| 亚洲男人的天堂在线观看| 亚洲欧美另类久久久精品2019|