设为首页 收藏本站
查看: 1167|回复: 0

[经验分享] SQL Server SQL分页查询

[复制链接]

尚未签到

发表于 2017-7-13 12:57:33 | 显示全部楼层 |阅读模式
  SQL Server SQL分页查询的几种方式
  目录
  0.    序言   
  1.    TOP…NOT IN…   
  2.    ROW_NUMBER()   
  3.    OFFSET…FETCH   
  4.    执行计划   
  5.    补充   


  • 0.序言
  总结一下SQL Server种常用的几种分页查询:
      本示例中用的时已有的表,建表不规范,Name作为主键,建议实际使用中专门设置主键并且WHERE条件中尽可能使用主键。
  参数说明:
  @pageSize:分页查询每页N条数据时每页期望的数据量N
      @offset:分页查询第I页每页N条数据时,第I页之前的N*(I-1)条数据
  举个栗子:假如我们要查询第3页的数据,每页10条数据,则 @pageSize为10,@offset为20。

1.TOP…NOT IN…   基本原理:查询 @pageSize 条数据,先使用一个子查询查询出符合查询条件的 @offset条数据的主键,再使用TOP @pageSize查询@pageSize条数据,并且再WHERE从句中使用 NOT IN 关键词来对数据进行筛选。
DSC0000.png


2.ROW_NUMBER()   基本原理:在SQL Server2005之后加入,可以使用 ROW_NUMBER()函数为查询出来的记录生成一个行号,需要指定一个ORDER BY 子句确定排序方式,排序方式不同,行号也可能不同。详细说明:ROW_NUMBER()
DSC0001.png

  本文只涉及OVER从句中跟随ORDER BY子句,partition by 从句不在本文讨论范围内,partition by 和OVER详细说明戳这里
DSC0002.png

  这里使用了两个ROW_NUMBER()函数的例子,这两个计算总行数的方式是不一样的,本文结尾处会对比一个两种方式的IO操作以说明哪种方式更适合

3.OFFSET…FETCH   OFFSET是SQL Server 2012中新增的语法,可以单独使用,也可与FETCH NEXT一起使用,单独使用OFFSET时是查询获取@offset之后所有的数据,如下图所示
DSC0003.png

  但我们想要的是分页查询,那就需要和FETCH NEXT联合使用,OFFSET后跟@offset参数,FETCH NEXT 后跟 @pageSize参数
DSC0004.png

  4.执行计划
  上面四种查询方式的执行计划如下:
DSC0005.png


5.补充   OFFSET…FETCH补充:
DSC0006.png

  关于参数,推荐用法:始终使用ROWS,始终使用NEXT
  -- OFFSET {@offset} ROWS FETCH NEXT {@pagesize} ROWS ONLY
  /*
  *使用 OFFSET-FETCH 中的限制:
      *** ORDER BY 是使用 OFFSET 和 FETCH 子句所必需的。
      *** OFFSET 子句必须与 FETCH 一起使用。永远不能使用 ORDER BY … FETCH。
      *** TOP 不能在同一个查询表达式中与 OFFSET 和 FETCH 一起使用。
      *** OFFSET/FETCH 行计数表达式可以是将返回整数值的任何算术、常量或参数表达式。该行计数表达式不支持标量子查询。
  */
  更多OFFSET信息参考这里
  对比一下ROW_NUMBER()两种计算数据总数方式的IO消耗:
DSC0007.png

  第一个是使用MAX(RowNum)来计算总数的,第二种是使用子查询的方式来计算总数。
  示例SQL:PagedQuery

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-393426-1-1.html 上篇帖子: SQL Server-聚焦计算列持久化(二十一) 下篇帖子: SQL Server 中统计信息直方图中对于没有覆盖到谓词预估以及预估策略的变化(SQL2012-->SQL2014-->SQL2016)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表