站長資訊網
        最全最豐富的資訊網站

        SQL server分頁方法有哪些

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

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

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

        要查詢的學生表的部分記錄

        SQL server分頁方法有哪些

        方法一:三重循環

        思路

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

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

        代碼實現

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

        查詢出的結果及時間

        SQL server分頁方法有哪些

        SQL server分頁方法有哪些

        方法二:利用max(主鍵)

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

        代碼實現

        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;

        查詢出的結果及時間

        SQL server分頁方法有哪些

        SQL server分頁方法有哪些

        方法三:利用row_number關鍵字

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

        SQL實現

        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;

        查詢出的結果及時間

        SQL server分頁方法有哪些

        SQL server分頁方法有哪些

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

        代碼實現

        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條數據。

        結果及運行時間

        SQL server分頁方法有哪些

        SQL server分頁方法有哪些

        封裝的存儲過程

        最后,我封裝了一個分頁的存儲過程,方便大家調用,這樣到時候寫分頁的時候,直接調用這個存儲過程就可以了。

        分頁的存儲過程

        create procedure paging_procedure (	@pageIndex int, -- 第幾頁 	@pageSize int  -- 每頁包含的記錄數 ) 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  -- 到時候直接調用就可以了,執行如下的語句進行調用分頁的存儲過程 exec paging_procedure @pageIndex=2,@pageSize=10;

        總結

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

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国语精品一区二区三区| 久久精品中文字幕久久| 久久国产精品-国产精品| 亚洲av永久无码精品网站 | 99精品人妻少妇一区二区| 日韩精品一区二区三区中文 | 国产精品三级在线观看无码| 久久无码精品一区二区三区| 高清日韩精品一区二区三区| 国产精品臀控福利在线观看| 国内精品久久久久影院日本| 亚洲精品无码久久久久sm| 麻豆精品视频在线观看91| 丰满人妻熟妇乱又伦精品劲| 四虎成人欧美精品在永久在线| 99久久国产综合精品麻豆| 国产精品v片在线观看不卡 | 成人国产精品秘 果冻传媒在线| 四虎4hu永久免费国产精品| 久久91精品久久91综合| 91麻豆精品视频| 2020亚洲男人天堂精品| 国产成人精品久久一区二区三区| 国99精品无码一区二区三区| 精品久久久噜噜噜久久久| 国内精品久久久人妻中文字幕| 麻豆国产在线精品国偷产拍| 亚洲精品V欧洲精品V日韩精品 | 国产成人精品亚洲日本在线| 国产成人精品一区二区秒拍| 国产精品对白交换视频| 国产精品视频第一区二区三区| 精品福利一区二区三区免费视频| 精品麻豆丝袜高跟鞋AV| 91老司机深夜福利精品视频在线观看 | 国产乱码精品一区二区三区中文 | 亚洲精品和日本精品| 在线成人精品国产区免费| 亚洲日韩国产AV无码无码精品| 亚洲精品乱码久久久久久按摩 | 91无码人妻精品一区二区三区L|