<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
這篇部落格講的是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關鍵字(是通過蒐集網上的其他人的方法總結的,應該目前只有這四種方法的思路,其他方法都是基於此變形的)。
要查詢的學生表的部分記錄
先取前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 ;
查詢出的結果及時間
先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;
查詢出的結果及時間
直接利用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;
查詢出的結果及時間
程式碼實現
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條資料。
結果及執行時間
封裝的儲存過程
最後,我封裝了一個分頁的儲存過程,方便大家呼叫,這樣到時候寫分頁的時候,直接呼叫這個儲存過程就可以了。
分頁的儲存過程
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公司升級後推出的新方法,所以應該理論上效能和可讀性都會更加好。
到此這篇關於SQL server分頁的四種方法的文章就介紹到這了,更多相關SQL server分頁內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45