婷婷久久综合九色综合,欧美成色婷婷在线观看视频,偷窥视频一区,欧美日本一道道一区二区

<tt id="bu9ss"></tt>
  • <span id="bu9ss"></span>
  • <pre id="bu9ss"><tt id="bu9ss"></tt></pre>
    <label id="bu9ss"></label>

    當(dāng)前位置:首頁 >  站長(zhǎng) >  數(shù)據(jù)庫(kù) >  正文

    SQL server分頁的4種方法示例 很全面

     2020-12-17 16:05  來源: 腳本之家   我來投稿 撤稿糾錯(cuò)

      阿里云優(yōu)惠券 先領(lǐng)券再下單

    這篇文章主要給大家介紹了關(guān)于SQL server分頁的4種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

    這篇博客講的是SQL server的分頁方法,用的SQL server 2012版本。下面都用pageIndex表示頁數(shù),pageSize表示一頁包含的記錄。并且下面涉及到具體例子的,設(shè)定查詢第2頁,每頁含10條記錄。

    首先說一下SQL server的分頁與MySQL的分頁的不同,mysql的分頁直接是用limit (pageIndex-1),pageSize就可以完成,但是SQL server 并沒有l(wèi)imit關(guān)鍵字,只有類似limit的top關(guān)鍵字。所以分頁起來比較麻煩。

    SQL server分頁我所知道的就只有四種:三重循環(huán);利用max(主鍵);利用row_number關(guān)鍵字,offset/fetch next關(guān)鍵字(是通過搜集網(wǎng)上的其他人的方法總結(jié)的,應(yīng)該目前只有這四種方法的思路,其他方法都是基于此變形的)。

    要查詢的學(xué)生表的部分記錄

    方法一:三重循環(huán) 思路

    先取前20頁,然后倒序,取倒序后前10條記錄,這樣就能得到分頁所需要的數(shù)據(jù),不過順序反了,之后可以將再倒序回來,也可以不再排序了,直接交給前端排序。

    還有一種方法也算是屬于這種類型的,這里就不放代碼出來了,只講一下思路,就是先查詢出前10條記錄,然后用not in排除了這10條,再查詢。

    代碼實(shí)現(xiàn)

    -- 設(shè)置執(zhí)行時(shí)間開始,用來查看性能的
    set statistics time on ;
    -- 分頁查詢(通用型)
    select *
    from (select top pageSize *
    from (select top (pageIndex*pageSize) *
    from student
    order by sNo asc ) -- 其中里面這層,必須指定按照升序排序,省略的話,查詢出的結(jié)果是錯(cuò)誤的。
    as temp_sum_student
    order by sNo desc ) temp_order
    order by sNo asc

    -- 分頁查詢第2頁,每頁有10條記錄
    select *
    from (select top 10 *
    from (select top 20 *
    from student
    order by sNo asc ) -- 其中里面這層,必須指定按照升序排序,省略的話,查詢出的結(jié)果是錯(cuò)誤的。
    as temp_sum_student
    order by sNo desc ) temp_order
    order by sNo asc
    ;

     

    查詢出的結(jié)果及時(shí)間

    方法二:利用max(主鍵)

    先top前11條行記錄,然后利用max(id)得到最大的id,之后再重新再這個(gè)表查詢前10條,不過要加上條件,where id>max(id)。

    代碼實(shí)現(xiàn)

    set statistics time on;
    -- 分頁查詢(通用型)
    select top pageSize *
    from student
    where sNo>=
    (select max(sNo)
    from (select top ((pageIndex-1)*pageSize+1) sNo
    from student
    order by sNo asc) temp_max_ids)
    order by sNo;


    -- 分頁查詢第2頁,每頁有10條記錄
    select top 10 *
    from student
    where sNo>=
    (select max(sNo)
    from (select top 11 sNo
    from student
    order by sNo asc) temp_max_ids)
    order by sNo;

    查詢出的結(jié)果及時(shí)間

    方法三:利用row_number關(guān)鍵字

    直接利用 row_number() over(order by id) 函數(shù)計(jì)算出行數(shù),選定相應(yīng)行數(shù)返回即可,不過該關(guān)鍵字只有在SQL server 2005版本以上才有。

    SQL實(shí)現(xiàn)

    set statistics time on;
    -- 分頁查詢(通用型)
    select top pageSize *
    from (select row_number()
    over(order by sno asc) as rownumber,*
    from student) temp_row
    where rownumber>((pageIndex-1)*pageSize);

    set statistics time on;
    -- 分頁查詢第2頁,每頁有10條記錄
    select top 10 *
    from (select row_number()
    over(order by sno asc) as rownumber,*
    from student) temp_row
    where rownumber>10;

    查詢出的結(jié)果及時(shí)間

    38

    第四種方法:offset /fetch next(2012版本及以上才有)

    代碼實(shí)現(xiàn)

    set statistics time on;
    -- 分頁查詢(通用型)
    select * from student
    order by sno
    offset ((@pageIndex-1)*@pageSize) rows
    fetch next @pageSize rows only;

    -- 分頁查詢第2頁,每頁有10條記錄
    select * from student
    order by sno
    offset 10 rows
    fetch next 10 rows only ;

    offset A rows ,將前A條記錄舍去,fetch next B rows only ,向后在讀取B條數(shù)據(jù)。

    結(jié)果及運(yùn)行時(shí)間

    4

    封裝的存儲(chǔ)過程

    最后,我封裝了一個(gè)分頁的存儲(chǔ)過程,方便大家調(diào)用,這樣到時(shí)候?qū)懛猪摰臅r(shí)候,直接調(diào)用這個(gè)存儲(chǔ)過程就可以了。

    分頁的存儲(chǔ)過程

    create procedure paging_procedure
    ( @pageIndex int, -- 第幾頁
    @pageSize int -- 每頁包含的記錄數(shù)
    )
    as
    begin
    select top (select @pageSize) * -- 這里注意一下,不能直接把變量放在這里,要用select
    from (select row_number() over(order by sno) as rownumber,*
    from student) temp_row
    where rownumber>(@pageIndex-1)*@pageSize;
    end

    -- 到時(shí)候直接調(diào)用就可以了,執(zhí)行如下的語句進(jìn)行調(diào)用分頁的存儲(chǔ)過程
    exec paging_procedure @pageIndex=2,@pageSize=10;

    總結(jié)

    根據(jù)以上四種分頁的方法執(zhí)行的時(shí)間可以知道,以上四種分頁方法中,第二,第三,第三四種方法性能是差不多的,但是第一種性能很差,不推薦使用。還有就是這篇博客這是測(cè)試了小量數(shù)據(jù),還沒有分頁大量數(shù)據(jù),所以不清楚在大量數(shù)據(jù)要分頁時(shí)哪種方法的性能更加好。我這里推薦第四種,畢竟第四種是SQL server公司升級(jí)后推出的新方法,所以應(yīng)該理論上性能和可讀性都會(huì)更加好。

    到此這篇關(guān)于SQL server分頁的4種方法的文章就介紹到這了,更多相關(guān)SQL server分頁方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

    來源:腳本之家

    鏈接:https://www.jb51.net/article/200647.htm

    申請(qǐng)創(chuàng)業(yè)報(bào)道,分享創(chuàng)業(yè)好點(diǎn)子。點(diǎn)擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!

    相關(guān)標(biāo)簽
    sqlserver

    相關(guān)文章

    熱門排行

    信息推薦