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