最近在分析 Sql Server 2012 中 offset and fetch 的新特性,发现 offset and fetch 无论语法的简洁还是功能的强大,都是相当相当不错的。其中  offset and fetch 最重要的新特性是 用来 分页,既然要分析 分页,就肯定要和之前的分页方式来比较了,特别是  Row_Number() 了,在比较过程中,发现了蛮多,不过最重要的,通过比较本质,得出了优劣,也和大家一起分享下。

准备工作,建立测试表:Article_Detail,主要是用来存放一些文章信息,测试的时间,都是从网易上面转载的新闻,同时,测试表数据字段类型是比较均匀的,为了更好的测试,表结构如下图:
内容:

数据量:129,991 条记录
语法分析
1. NTILE() 的分页方法
NTILE()  方法可以用来分页,但是应用场景十分的狭窄,并且性能差劲,和 Row_Number()  与 offset fetch 分页比起来没有任何优势,也只有在只读表上面分页的话,还是比较合适的;虽然不好用,但是还能来分页的,所以只简单的介绍下。
语法:

NTILE (integer_expression) OVER ( [ <partition_by_clause> ] < order_by_clause > )

将有序分区中的行分发到指定数目的组中。 各个组有编号,编号从一开始。 对于每一个行,NTILE 将返回此行所属的组的编号。
测试中用到的 Sql 语句 : 
set statistics time on
set statistics io on
set statistics profile on;with #pager as
(
select ID,Title,NTILE(8666) OVER(Order By ID) as pageid from Article_Detail
)
select ID,Title from #pager where pageid=50set statistics profile on; 

其中上述数字中的 8666 是根据  RowCount  / Pagesize 计算出来的,不过多介绍,可以自行参考 MSDN的
2. ROW_NUMBER() 的分页方法
在 Sql Server 2000 之后的版本中,ROW_NUMBER() 这种分页方式一直都是很不错的,比起之前的游标分页,性能好了很多,因为 ROW_NUMBER() 并不会引起全表扫表,但是,语法比较复杂,并且,随着页码的增加,性能也越来越差。
语法 :

ROW_NUMBER ( ) OVER ( [ PARTITION BY value_expression , ... [ n ] ] order_by_clause )

测试中用到的 Sql 语句:
dbcc freeproccache
dbcc dropcleanbuffers
set statistics time on
set statistics io on
set statistics profile on;with #pager as
(
select ID,Title,ROW_NUMBER() OVER(Order By ID) as rowid from Article_Detail
)
select ID,Title from #pager where rowid between (15 * (50-1)+1) and 15 * 50set statistics profile off;

3. Offset and Fetch 的分页方法
语法:
OFFSET { integer_constant | offset_row_count_expression } { ROW | ROWS }FETCH { FIRST | NEXT } { integer_constant | fetch_row_count_expression } { ROW | ROWS } ONLY

从语法可以看出来 两个方法 后面不但能接 intege 类型的参数,还能接 表达式的,比如  1*2 +3 之类的,同时, Row 或者 Rows 是不区分大小写和单复数的哦 
在看测试用的 Sql 语句,真的是简洁的不能再简洁了,看两遍都能记住的语法,分页可以如此的简洁:
dbcc freeproccache
dbcc dropcleanbuffers
set statistics time on
set statistics io on
set statistics profile on;select ID,Title from Article_Detail order by id OFFSET (15 * (50-1)) ROW FETCH NEXT 15 rows onlyset statistics profile off; 

一句就搞定!
性能比较
1. NTILE() 的执行计划

从执行计划中,就可以看出来,进行了一次全表扫表,两次 Nested Loops ,还有无数其他运算,就一次全表扫表,就知道性能之差了
2. ROW_NUMBER() 的执行计划 

从执行计划中可以看出来, 聚集索引扫描占用了100% 的资源,但是通过  EstimateRows = 100 和 Rows = 750 可以看出来,并没有进行全表扫描,并且IO 操作很小,所以性能还是很不错的
3. Offset and Fetch 的 执行计划

执行计划只有3行,并且占用资源 100% 的IO 操作 ,EstimateRows = 100 和 Rows = 750 是和 ROW_NUMBER() 完全一样的,但是其他的一些操作却少了很多,也就是说,并没有全表扫描,并降低了CPU 的消耗。
综合比较:
在 Sql Server 2012 里面,分页方法中,Offset and Fetch 同 ROW_NUMBER() 比较起来,无论是性能还是语法,都是有优势的。
但是性能方面,优势并不是太大,两者 的 IO 消耗完全相同,只是 在 CPU 方面,Offset and Fetch 方面要好一些,但是不明显。如果对于一个 每秒都要处理成千上万条的分页Sql语句的DB 来说,Offset and Fetch 在CPU 方面的优势会比较明显的,否则,性能的提升并不明显。
语法方面 Offset and Fetch 则是十分的简洁,一句搞定,比起 Row_Number() 好了太多 ~
同是 Offset and Fetch 并不仅仅可以用来分页哦,具体其他使用,大家可以自行参考 MSDN 

转载于:https://www.cnblogs.com/firstdream/p/7828883.html

Sql Server 2012 分页方法分析(offset and fetch)相关推荐

  1. 一起玩转SQL Server 2012 下的分析服务

    转载自:https://blog.csdn.net/aspnetx/article/details/8712286 提到SQL Server 2012的分析服务,那么不得不先说下商业智能,它是一个由数 ...

  2. 浅谈SQL Server数据库分页

    数据库分页是老生常谈的问题了.如果使用ORM框架,再使用LINQ的话,一个Skip和Take就可以搞定.但是有时由于限制,需要使用存储过程来实现.在SQLServer中使用存储过程实现分页的已经有很多 ...

  3. SQL Server 2012 OFFSET/FETCH NEXT分页示例

    原文:http://beyondrelational.com/modules/29/presentations/483/scripts/12983/sql-server-2012-server-sid ...

  4. 在SQL Server中分页结果的最佳方法是什么

    如果您还希望获得结果总数(在进行分页之前),那么在SQL Server 2000.2005.2008.2012中对结果进行分页的最佳方法是(性能明智的)? #1楼 最终, Microsoft SQL ...

  5. 微软BI 之SSAS 系列 - 在 SQL Server 2012 下查看 SSAS 分析服务的模型以及几个模型的简单介绍...

    在SSDT中部署一个 SSAS 项目到本地服务器上出现错误. You cannot deploy the model because the localhost deployment server i ...

  6. 2012服务器自动备份,SQL SERVER 2012数据库自动备份的方法

    为了防止数据丢失,这里给大家介绍SQL SERVER2012数据自动备份的方法: 一.打开SQL SERVER 2012,如图所示: 服务器类型:数据库引擎: 服务器名称:127.0.0.1(本地), ...

  7. SQL Server 2012安装时报错,错误 0x80070422怎么解决?解决方法。

    SQL Server 2012安装时报错,错误 0x80070422怎么解决?解决方法. 参考文章: (1)SQL Server 2012安装时报错,错误 0x80070422怎么解决?解决方法. ( ...

  8. sql server 2012远程链接的方法及步骤

    首先说下什么是sql server:(以下是应用某度某科的内容) SQL Server 是Microsoft 公司推出的关系型数据库管理系统.具有使用方便可伸缩性好与相关软件集成程度高等优点,可跨越从 ...

  9. 使用 SQL Server 2012 Analysis Services Tabular Mode 表格建模 图文教程

    原文 http://www.cnblogs.com/biwork/archive/2013/05/22/3093896.html BI Work 使用 SQL Server 2012 Analysis ...

最新文章

  1. BZOJ1042 [HAOI2008]硬币购物
  2. java.lang.NoClassDefFoundError: org/apache/tomcat/util/res/StringManager
  3. ML之kNN:k最近邻kNN算法的简介、应用、经典案例之详细攻略
  4. Qt中为工程添加资源文件、给按钮添加图片
  5. SpringBoot(Thymeleaf)前端html页面直接的传参和判定
  6. antimalware service executable占用内存过高_Win10系统svchost.exe进程占用内存和网速过高的解决方法...
  7. FastDFS之文件服务器集群部署详解
  8. mongodb的sharding架构搭建
  9. 2.微型计算机系统的基本结构及计算机各个部件的功能
  10. sqoop各类命令示范
  11. WebService实现文件上传下载
  12. 计算机等级的判断,计算机等级考试一级WPS判断题及答案
  13. QT绘图底层是如何适配各种操作系统的
  14. linux中文输入法配置
  15. ERP和进销存系统区别是什么
  16. 爬虫基础篇之多途径抓取失信人名单
  17. 计算机c盘主要放那些,c盘哪些文件可以删除(电脑C盘文件夹哪些可以删除?)...
  18. wifi认证取消html查看器,wifi网页认证怎么设置
  19. 用户显示图片的服务器是什么,显示服务器上的图片怎么写
  20. 一起谈.NET技术,.NET十年(下)

热门文章

  1. 《领域驱动设计:软件核心复杂性应对之道(修订版)》—第2章 2.1节模式:Ubiquitous Language...
  2. transfer function
  3. gitlab开启https加密 and 全站https
  4. dedeCMS,标准的MVC框架运行原理和缓存
  5. 斯坦福NLP笔记72 —— The Inverted Index
  6. Tech·Ed 2006博客园聚会
  7. C/C++产生随机数
  8. C++实现大数的加法
  9. 推荐一个非常实用的导航路径规划网站
  10. python用Levenshtein计算文本相似度