<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    SQL2005中row_number( )、rank( )、dense_rank( )、ntile( )函數的用法(2)

    SQL server 2005新增的幾個函數,分別是row_number( )rank( )、,DENSE_RANK( )ntile( )下面以實例分別簡單講解。

    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, Gender FROM 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段了。

     

    posted on 2011-08-19 16:45 SkyDream 閱讀(269) 評論(0)  編輯  收藏 所屬分類: SQL語句

    <2011年8月>
    31123456
    78910111213
    14151617181920
    21222324252627
    28293031123
    45678910

    導航

    統計

    常用鏈接

    留言簿(3)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 在线播放免费人成毛片乱码| 2015日韩永久免费视频播放| 亚洲最大AV网站在线观看| 男女午夜24式免费视频| 久久亚洲最大成人网4438| 五月婷婷亚洲综合| 亚洲免费在线视频| 亚洲欧洲AV无码专区| 亚洲精品国产自在久久| 蜜桃成人无码区免费视频网站 | 亚洲精品中文字幕麻豆 | 91亚洲精品视频| 尤物永久免费AV无码网站| 中文在线免费不卡视频| 亚洲丰满熟女一区二区v| 亚洲国产一级在线观看| 亚洲欧洲免费无码| 久久一区二区免费播放| 亚洲影院天堂中文av色| 精品久久香蕉国产线看观看亚洲| 97视频热人人精品免费| 国产免费久久精品99久久| 亚洲综合av一区二区三区 | 亚洲综合av一区二区三区| 国产亚洲色婷婷久久99精品| 免费无码黄网站在线观看| 免费观看男人吊女人视频| 羞羞视频在线免费观看| 亚洲AV无码乱码麻豆精品国产| 亚洲无码精品浪潮| 免费无码看av的网站| 99久久99久久精品免费观看| 无遮挡国产高潮视频免费观看| 亚洲www在线观看| 久久青青草原亚洲av无码app | 亚洲av手机在线观看| 成人毛片免费视频| 99在线观看免费视频| 中文成人久久久久影院免费观看| 久久亚洲精品无码网站| 色婷五月综激情亚洲综合|