欧美亚洲中文,在线国自产视频,欧洲一区在线观看视频,亚洲综合中文字幕在线观看

      1. <dfn id="rfwes"></dfn>
          <object id="rfwes"></object>
        1. 站長(zhǎng)資訊網(wǎng)
          最全最豐富的資訊網(wǎng)站

          SQL server分頁(yè)方法有哪些

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

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

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

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

          SQL server分頁(yè)方法有哪些

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

          思路

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

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

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

          -- 設(shè)置執(zhí)行時(shí)間開(kāi)始,用來(lái)查看性能的 set statistics time on ; -- 分頁(yè)查詢(通用型) 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  -- 分頁(yè)查詢第2頁(yè),每頁(yè)有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í)間

          SQL server分頁(yè)方法有哪些

          SQL server分頁(yè)方法有哪些

          方法二:利用max(主鍵)

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

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

          set statistics time on; -- 分頁(yè)查詢(通用型) 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;   -- 分頁(yè)查詢第2頁(yè),每頁(yè)有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í)間

          SQL server分頁(yè)方法有哪些

          SQL server分頁(yè)方法有哪些

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

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

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

          set statistics time on; -- 分頁(yè)查詢(通用型) 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; -- 分頁(yè)查詢第2頁(yè),每頁(yè)有10條記錄 select top 10 *  from (select row_number()  over(order by sno asc) as rownumber,*  from student) temp_row where rownumber>10;

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

          SQL server分頁(yè)方法有哪些

          SQL server分頁(yè)方法有哪些

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

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

          set statistics time on; -- 分頁(yè)查詢(通用型) select * from student order by sno  offset ((@pageIndex-1)*@pageSize) rows fetch next @pageSize rows only;  -- 分頁(yè)查詢第2頁(yè),每頁(yè)有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í)間

          SQL server分頁(yè)方法有哪些

          SQL server分頁(yè)方法有哪些

          封裝的存儲(chǔ)過(guò)程

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

          分頁(yè)的存儲(chǔ)過(guò)程

          create procedure paging_procedure (	@pageIndex int, -- 第幾頁(yè) 	@pageSize int  -- 每頁(yè)包含的記錄數(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í)行如下的語(yǔ)句進(jìn)行調(diào)用分頁(yè)的存儲(chǔ)過(guò)程 exec paging_procedure @pageIndex=2,@pageSize=10;

          總結(jié)

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

          贊(0)
          分享到: 更多 (0)
          網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)