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

北京北大青鳥指導: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段了。

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

      宅男66日本亚洲欧美视频| 国产精品爱久久久久久久| 亚洲精品久久久一区二区三区| 国产精品高潮呻吟视频 | 欧美一区视频在线| 亚洲精品在线电影| 在线精品国产成人综合| 国产精品xxx在线观看www| 欧美成人一区二区三区在线观看| 亚洲欧美激情视频| 日韩视频一区二区三区| 在线观看福利一区| 国产女人18毛片水18精品| 欧美日韩久久久久久| 久久久久久成人| 欧美亚洲视频在线看网址| 亚洲看片免费| 亚洲国产婷婷| 亚洲国产精品女人久久久| 好看的亚洲午夜视频在线| 国产精品久久久久久五月尺| 欧美精品久久99| 欧美风情在线| 欧美激情1区| 麻豆精品一区二区av白丝在线| 欧美一级夜夜爽| 香蕉久久夜色| 亚洲欧美视频在线观看| 亚洲午夜在线| 亚洲自拍高清| 欧美亚洲一区二区在线| 午夜精品影院| 性做久久久久久久久| 欧美在线|欧美| 久久精品国产免费| 久久亚洲影音av资源网| 欧美福利视频在线观看| 欧美14一18处毛片| 欧美日韩福利视频| 欧美三级在线播放| 国产欧美精品在线播放| 国产在线高清精品| 亚洲国产福利在线| 亚洲另类黄色| 亚洲一区二区黄色| 欧美一区二区三区四区夜夜大片| 久久精品国产在热久久| 欧美不卡在线| 欧美视频一区二| 国产亚洲精品久久久久婷婷瑜伽| 国产综合色产在线精品| 亚洲激情第一区| 亚洲一级特黄| 久久综合伊人77777| 欧美日韩不卡在线| 国产精品一区视频网站| 在线看片日韩| 99精品热6080yy久久| 欧美一区91| 欧美日韩国产精品专区| 国产精品揄拍一区二区| 极品少妇一区二区| 亚洲午夜精品视频| 噜噜噜在线观看免费视频日韩| 久久日韩粉嫩一区二区三区| 欧美aⅴ一区二区三区视频| 欧美日一区二区三区在线观看国产免| 国产精品久久久久久av下载红粉 | 亚洲影视在线| 米奇777在线欧美播放| 欧美三级午夜理伦三级中文幕 | 久久这里有精品视频| 欧美日韩免费视频| 在线观看欧美日韩国产| 午夜精品短视频| 欧美日韩成人一区二区| 狠狠色狠狠色综合日日小说| 亚洲一区二区免费视频| 欧美好骚综合网| 精品成人在线视频| 亚洲在线1234| 国产精品不卡在线| av不卡在线观看| 欧美sm重口味系列视频在线观看| 国产日韩综合| 性做久久久久久免费观看欧美| 欧美久久久久免费| 亚洲激情欧美| 久久深夜福利| 1024国产精品| 久久婷婷国产综合国色天香| 国产亚洲一区二区三区在线播放| 在线视频欧美日韩精品| 欧美日韩一区自拍| 一区二区三区导航| 欧美日韩国产二区| 亚洲一区二区成人| 国产精品高精视频免费| 亚洲天堂成人在线视频| 欧美色综合网| 亚洲一区二区三区欧美| 国产精品久久久久av| 亚洲欧美在线免费观看| 国产精品女主播一区二区三区| 亚洲欧美视频在线| 国产一区二区三区无遮挡| 久久精品国产77777蜜臀 | 国内精品伊人久久久久av影院 | 在线成人亚洲| 欧美jizz19性欧美| 亚洲精品乱码久久久久久按摩观| 欧美日韩成人在线播放| 在线亚洲成人| 国产欧美精品在线播放| 久久精品一区蜜桃臀影院 | 久热精品视频在线| 亚洲人成在线观看网站高清| 欧美日韩国产黄| 亚洲综合激情| 国产在线观看91精品一区| 男女激情久久| 亚洲在线1234| 国产一区二区高清| 免费在线日韩av| 一区二区电影免费在线观看| 国产精品久久久一本精品| 欧美一级精品大片| 91久久久在线| 国产精品久久久久久久久久ktv| 久久国产一区| 亚洲日韩成人| 国产一区二区精品在线观看| 欧美激情一区二区三区在线| 一区二区激情视频| 国产一区二区三区久久久久久久久 | 国产欧美欧美| 欧美aa国产视频| 性做久久久久久久久| 亚洲美女尤物影院| 国产情人节一区| 欧美片在线观看| 久久免费黄色| 亚洲一区国产| 日韩午夜在线观看视频| 激情综合色丁香一区二区| 国产精品进线69影院| 欧美韩日精品| 欧美成人午夜激情在线| 久久久精品国产一区二区三区| 一区二区久久久久| 亚洲第一精品久久忘忧草社区| 国产精品入口麻豆原神| 欧美日韩日本网| 奶水喷射视频一区| 久久青草欧美一区二区三区| 午夜在线视频观看日韩17c| 在线亚洲美日韩| 日韩视频―中文字幕| 亚洲激情小视频| 亚洲二区三区四区| 在线观看日韩一区| 在线成人免费视频| 亚洲大片免费看| 亚洲人成高清| 亚洲人成在线观看网站高清| 亚洲国产欧美久久| 亚洲第一在线视频| 亚洲国内自拍| 亚洲精品一区二区三区樱花| 亚洲国产精品成人| 最新国产拍偷乱拍精品 | 欧美日韩国产色站一区二区三区| 欧美a级在线| 欧美成人官网二区| 欧美激情第8页| 欧美日韩色婷婷| 国产精品伦一区| 国产伦精品一区二区三区视频黑人| 国产精品一区免费视频| 国产午夜久久久久| 在线成人国产| 99视频国产精品免费观看| 99综合视频| 先锋影音久久| 美日韩精品视频免费看| 欧美激情亚洲自拍| 国产精品老女人精品视频| 国产精品视频免费在线观看| 国产一区二区av| 亚洲激情视频网| 中文成人激情娱乐网| 欧美一区亚洲| 欧美xart系列高清| 欧美色图天堂网| 狠狠干成人综合网| 91久久精品网| 欧美亚洲免费| 欧美韩国日本综合| 国产美女搞久久| 亚洲精品国产欧美|