请问下sqlserver2008分页语句怎么写? 10

mytencent:1252074355... mytencent:1252074355 展开
 我来答
klee2000163
2014-08-19 · TA获得超过102个赞
知道答主
回答量:30
采纳率:100%
帮助的人:38万
展开全部
1、这种SQL分页语句,是用正反向排序的原理写:
先按你需要的排序,取到你要的页数的数据;再从其中按倒序取,每页要显示多少行就取多少个。这样取出的就是需要的数据;再按需要的排序重新排下序就是所要取的第n页的数据了;
然后要取的页数用参数传递,就可以按参数取任意页的数据集。

2、这种做法的缺陷是:
用来排序的字段必须是关键数据集,即能唯一确定数据行的字段集;排序字段相同的数据行有多个的话,则这几行之间的排序会有问题;

3、排序字段是关键数据集的话,不用说了,直接用现有字段实现就是;参照加行号的语句,去掉rownum,按你自己的字段写order子句 替换rownum的排序就是;而且最内层还可以去掉一层子查询;

4、排序字段不是关键数据集的话,需要加个行号字段,作为排序字段:从1开始,递增1个的顺序(1、2、……);2008的话,支持row_number(),就好办多了,否则就只好自己控制生成一个序列字段,再合并到数据集上了。

5、加个行号字段的语句具体如下,其中具体表、字段,按你自己的实际情况代换下:
declare @iPage int --所取的页的序数 (第几页)
declare @iPageNum int --所取的数据行数(除最后一页外,每页所取的行数应该都是一样的)
declare @iRecordNumber int --取@iPage页时,结尾记录所在行数
declare @iRecordCount int --总记录行数

--变量初始化
set @iPage=2 --可用参数传递
set @iPageNum=10 --默认每页取10行
set @iRecordNumber=@iPage*@iPageNum
select @iRecordCount=count(任意字段,最好不要用*) from 你取数据的表

--取最后一页时,重算结尾所在行数(@iRecordNumber)、所取记录数(@iPageNum)
if @iRecordNumber>@iRecordCount
begin
set @iRecordNumber=@iRecordCount
if (@iRecordNumber%@iPageNum)>0
set @iPageNum=@iRecordNumber%@iPageNum
end

declare @strSQL varchar(max)
set @strSQL='select * from ('
set @strSQL=@strSQL + 'select top '+ convert(varchar(5),@iPageNum) +' * from('
set @strSQL=@strSQL + 'select top '+ convert(varchar(7),@iRecordNumber) +' * from'
set @strSQL=@strSQL + '('
set @strSQL=@strSQL + 'select row_number()over(order by 你需要的排序字段及正反序)as RowNum,*from 你取数据的表'
set @strSQL=@strSQL + ') a order by rownum'
set @strSQL=@strSQL + ') b order by rownum desc'
set @strSQL=@strSQL + ') c order by rownum'

exec(@strSQL)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式