Sql Server中的分页Sql

1. 在SQL SERVER 2005 以后提供了ROW_NUMBER方法。因此可以利用TOP以及ROW_NUMBER来写分页函数

这个方法会写在方法中,是用来对原SQL进行包装的。假设原SQL为select * from A

1. 首先,假设起始位置为0,根据每页的显示条数,改装SQL,为了不影响到原SQL的排序条件,需要添加一个临时列。

@START :起始位置

@PERNUM:每页条数

SELECT (@START+@PERNUM) 0 temp, * FROM A

2. 对以上的结果集进行编号,利用ROW_NUMBER()

SELECT ROW_NUMBER() OVER(ORDER BY temp) rowNum, * FROM(

       SELECT (@START+@PERNUM) 0 temp, * FROM A

) t

3. 根据起始位置进行过滤

 

SELECT * FROM (
    SELECT ROW_NUMBER() OVER(ORDER BY temp) rowNum, * FROM(

       SELECT (@START+@PERNUM) 0 temp, * FROM A

    ) t
) tt 
WHERE tt.rowNum > @START


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Bing Forever

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值