加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQLServer的分页

发布时间:2020-12-12 15:31:01 所属栏目:MsSql教程 来源:网络整理
导读:特点:一次查询,数据库只返回一页的数据。而不是取出所有的数据。 说明: pagesize: 每页显示记录数 cureentpage:当前页数 select * from (?? select TOP pagesize * FROM ( SELECT TOP pagesize*cureentpage?? * from user_table?? ORDER BY id ASC ) as

特点:一次查询,数据库只返回一页的数据。而不是取出所有的数据。
说明:

pagesize: 每页显示记录数
cureentpage:当前页数

select * from (?? select TOP pagesize * FROM ( SELECT TOP pagesize*cureentpage?? * from user_table?? ORDER BY id ASC ) as aSysTable?? ORDER BY id DESC ) as bSysTable?? ORDER BY id ASC


例子说明:

假如数据库表如下:

user_table:

id:主键,自增
username:字符
password:字符

假设有80条记录,每页显示10条记录,id 从1到80


现在按照id升序排列取出第三页的数据应该为:所取得记录的id 应该为 21到30。

这时该语句应该为:

select * from (?? select TOP 10 * FROM ( SELECT TOP 30?? * from user_table?? ORDER BY id ASC ) as aSysTable?? ORDER BY id DESC ) as bSysTable?? ORDER BY id ASC

原理如下:

先按照id从小到大升序取出30条记录(3*10),也就是:id 在 1-30 之间的记录 (SELECT TOP 30?? * from user_table?? ORDER BY id ASC)

然后按照ID降序排列这30条记录,得到记录为id 在:从30到 1??

然后在这些30条记录中取出前10条记录:取得的记录为:id 在30-21之间。这就是我们需要的数据,但这时是按照降序排列的,不符合要求。

最后在重新排序得到最终我们需要的数据。id在21-30之间。


希望对大家有所帮助。

如有问题,希望和大家一块交流。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读