sqlserver分页的两种写法分别介绍

第一种是最传统的写法,用存储过程中的变量作为分页的乘数


复制代码 代码如下:

[c-sharp] view plaincopyprint?create proc p_paged1

@pagesize int,@currentpage int

as

select top (@pagesize) * from student

where id not in

(select top (@pagesize*(@currentpage-1)) id from student)

go

exec p_paged1 2,3

create proc p_paged1

@pagesize int,@currentpage int

as

select top (@pagesize) * from student

where id not in

(select top (@pagesize*(@currentpage-1)) id from student)

go

exec p_paged1 2,3

–sql server2005以后的分页语句


复制代码 代码如下:

[c-sharp] view plaincopyprint?create proc p_paged2

@pagestart int, @pageend int

as

select * from

(select *,row_number() over(order by id desc) as rnum

from student) t

where t.rnum between @pagestart and @pageend

go

exec p_paged2 5,10

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐