SQL Server 2012 实现分页新语法

最近一直在看SQL Server的书,不过看的都是基础的查询流,查询在工作中用到的最多,所以能正确地查询出想要的数据也是很重要的嘛。

在书上看到在SQL Server 2012新增了一种实现分页的查询方法,感觉比原来的方便一点,因此记录一下,如能帮助到大家,也是非常开心的~

 

以前分页的时候,我基本都是用ROW_NUMBER()函数,和在WHERE语句中用BETWEEN AND 来实现的;每次都得写子查询,感觉挺麻烦的,例:

SELECT *
FROM (
    SELECT 
        ID,
        ROW_NUMBER() OVER(ORDER BY [Datetime] DESC) AS num
    FROM dbo.tblUser
) AS t
WHERE t.num BETWEEN 11 AND 20

 

在SQL Server 2012中就不需要写子查询啦,直接在ORDER BY语句中就可以实现分页啦!例:

SELECT
    ID,
    ROW_NUMBER() OVER(ORDER BY [Datetime] DESC) AS num
FROM dbo.tblUser
ORDER BY num
OFFSET 10 ROWS
FETCH NEXT 10 ROWS ONLY

  需注意的是:该语法是在ORDER BY 子句中引入了两个新的参数 OFFSET 和  FETCH,因此它们必须在order by语句只有使用,且必须结合使用才能使分页正常运作。

  OFFSET指定在返回查询结果之前要跳过的行数,FETCH指定OFFSET之后返回的行数。

转载于:https://www.cnblogs.com/zzgblog/p/5325571.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值