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
;方法二:利用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;
方法三:利用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;
第四種方法: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 ;
分頁的儲存過程
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 分頁查詢
ps,此文是純個人筆記 公司裡乙個專案裡用到了一種資料庫分頁查詢的方式 1 定義乙個臨時的table 這個table有乙個自增的之間id,和要查的資料表的主鍵id 2 再一次查詢,用id在分頁數段來and 一下結果 具體操作如下 定義個臨時表 temptable declare temptable ...
SQL SERVER 分頁查詢
方式一 row number select top 頁大小 from select row number over order by id as rownumber,from table1 as a where rownumber 頁大小 當前頁 1 註解 首先利用row number 為table...
Sql Server 分頁查詢
sql server 中通過sql語句實現分頁查詢 方案一 利用not in和select top分頁 select top 頁大小 from 表名 where id not in select top 頁大小 頁數 1 id from 表名 order by id order by id 方案二 ...