SQL Server 2008中SQL应用系列--目录索引

前些天看到一篇文章《SQL Server 2012 - Server side paging demo using OFFSET/FETCH NEXT》,原文地址。作者在文中称,要SQL Server 2012使用OFFSET/FETCH NEXT分页,比SQL Server 2005/2008中的RowNumber()有显著改进。今天特地作了简单测试。现将过程分享如下:

附:我的测试环境为:
SQL Server 2012,命名实例

Microsoft SQL Server 2012 - 11.0.2100.60 (Intel X86) 
Feb 10 2012 19:13:17 
Copyright (c) Microsoft Corporation
Enterprise Edition on Windows NT 6.0 <X86> (Build 6002: Service Pack 2)

沿用上文的测试数据库和表:

  1. IF OBJECT_ID('DemoPager2012') IS NOT NULL
  2. DROP DataBase DemoPager2012
  3. GO
  4. CREATE Database DemoPager2012
  5. GO
  6. USE DemoPager2012
  7. GO/*
  8. Setup script to create the sample table and fill it with
  9. sample data.
  10. */
  11. IF OBJECT_ID('Customers','U') IS NOT NULL
  12. DROP TABLE Customers
  13. CREATE TABLE Customers ( CustomerID INT primary key identity(1,1),
  14. CustomerNumber CHAR(4),
  15. CustomerName VARCHAR(50),
  16. CustomerCity VARCHAR(20) )
  17. GOTRUNCATE table Customers
  18. GO
  19. DBCC DROPCLEANBUFFERS
  20. DBCC FREEPROCCACHE
  21. /*****运用CTE递归插入,速度较快,邀月注***********************/
  22. WITH Seq (num,CustomerNumber, CustomerName, CustomerCity) AS
  23. (SELECT 1,cast('0000'as CHAR(4)),cast('Customer 0' AS NVARCHAR(50)),cast('X-City' as NVARCHAR(20))
  24. UNION ALL
  25. SELECT num + 1,Cast(REPLACE(STR(num, 4), ' ', '0') AS CHAR(4)),
  26. cast('Customer ' + STR(num,6) AS NVARCHAR(50)),
  27. cast(CHAR(65 + (num % 26)) + '-City' AS NVARCHAR(20))
  28. FROM Seq
  29. WHERE num <= 10000
  30. )
  31. INSERT INTO Customers (CustomerNumber, CustomerName, CustomerCity)
  32. SELECT CustomerNumber, CustomerName, CustomerCity
  33. FROM Seq
  34. OPTION (MAXRECURSION 0)

插入1万条数据后,在SQL Server 2008 R2中执行Row_Number():

  1. /*
  2. Server side paging demo using ROW_NUMBER() - SQL Server
  3. 2005/2008 version.
  4. */
  5. DBCC DROPCLEANBUFFERS
  6. DBCC FREEPROCCACHE
  7. SET STATISTICS IO ON;
  8. SET STATISTICS TIME ON;
  9. GO
  10. DECLARE @page INT, @size INT
  11. SELECT @page = 3, @size = 10
  12. ;WITH cte AS (
  13. SELECT TOP (@page * @size)
  14. CustomerID,
  15. CustomerName,
  16. CustomerCity,
  17. ROW_NUMBER() OVER(ORDER BY CustomerName ) AS Seq,
  18. COUNT(*) OVER(PARTITION BY '') AS Total
  19. FROM Customers
  20. WHERE CustomerCity IN ('A-City','B-City')
  21. ORDER BY CustomerName ASC
  22. )
  23. SELECT * FROM cte
  24. WHERE seq BETWEEN (@page - 1 ) * @size + 1 AND @page * @size
  25. ORDER BY seq;
  26. GO
  27. SET STATISTICS IO OFF ;
  28. SET STATISTICS TIME OFF;
  29. GO

SQL Server 2012中执行OFFSET/FETCH NEXT语句如下:

  1. /*
  2. Server side paging demo using the new enhancements added
  3. in SQL Server 2012
  4. */
  5. DBCC DROPCLEANBUFFERS
  6. DBCC FREEPROCCACHE
  7. SET STATISTICS IO ON;
  8. SET STATISTICS TIME ON;
  9. GO
  10. DECLARE @page INT, @size INT
  11. SELECT @page = 3, @size = 10
  12. SELECT
  13. *,
  14. COUNT(*) OVER(PARTITION BY '') AS Total
  15. FROM Customers
  16. WHERE CustomerCity IN ('A-City','B-City')
  17. ORDER BY CustomerID
  18. OFFSET (@page -1) * @size ROWS
  19. FETCH NEXT @size ROWS ONLY;
  20. GO
  21. SET STATISTICS IO OFF;
  22. SET STATISTICS TIME OFF;
  23. GO

在SQL Server 2012中执行如下语句:

  1. DBCC DROPCLEANBUFFERS
  2. DBCC FREEPROCCACHE
  3. SET STATISTICS IO ON;
  4. SET STATISTICS TIME ON;
  5. GO
  6. DECLARE @page INT, @size INT
  7. SELECT @page = 3, @size = 10
  8. ;WITH cte AS (
  9. SELECT TOP (@page * @size)
  10. CustomerID,
  11. CustomerName,
  12. CustomerCity,
  13. ROW_NUMBER() OVER(ORDER BY CustomerName ) AS Seq,
  14. COUNT(*) OVER(PARTITION BY '') AS Total
  15. FROM Customers
  16. WHERE CustomerCity IN ('A-City','B-City')
  17. ORDER BY CustomerName ASC
  18. )
  19. SELECT * FROM cte
  20. WHERE seq BETWEEN (@page - 1 ) * @size + 1 AND @page * @size
  21. ORDER BY seq;
  22. SELECT
  23. *,
  24. COUNT(*) OVER(PARTITION BY '') AS Total
  25. FROM Customers
  26. WHERE CustomerCity IN ('A-City','B-City')
  27. ORDER BY CustomerID
  28. OFFSET (@page -1) * @size ROWS
  29. FETCH NEXT @size ROWS ONLY;
  30. GO
  31. SET STATISTICS IO OFF;
  32. SET STATISTICS TIME OFF;
  33. GO

结论:无论是从逻辑读取数还是响应时间实际执行行数等关键参数看,SQL Server 2012提供的OFFSET/FETCH NEXT分页方式都比Row_Number()方式有了较大的提升。

邀月注:本文版权由邀月和CSDN共同所有,转载请注明出处。
助人等于自助!   3w@live.cn

SQL Server 2012提供的OFFSET/FETCH NEXT与Row_Number()对比测试 [T]的更多相关文章

  1. SQL Server 2012提供的OFFSET/FETCH NEXT与Row_Number()对比测试(转)

    原文地址:http://www.cnblogs.com/downmoon/archive/2012/04/19/2456451.html 在<SQL Server 2012服务端使用OFFSET ...

  2. 《SQL Server 2012 T-SQL基础》读书笔记 - 2.单表查询

    Chapter 2 Single-Table Queries GROUP BY之后的阶段的操作对象就是组(可以把一组想象成很多行组成的)了,HAVING负责过滤掉一些组.分组后的COUNT(*)表示每 ...

  3. SQL Server 2012 AlwaysOn集群配置指南

    1. AlwaysOn介绍 AlwaysOn是SQL Server 2012提供的全新综合.灵活.高效经济的高可用性和灾难恢复解决方案.它整合了镜像和群集的功能,基于OS 故障转移群集(Windows ...

  4. [转]SQL Server 2012 的 T-SQL 新功能 – 新的数据分析函数(LEAD、LAG)

    当您需要在 SQL Server 中利用 T-SQL 比较结果集的每一列跟前一列或后一列的差异时,在过去可能需要利用 CURSOR 搭配临时表变量,或是透过递归 CTE 来达到这个效果,如今 SQL ...

  5. Microsoft SQL Server 2012安装说明

    Microsoft SQL Server 2012安装说明 环境:Windows8, Windows7, WinVista, Win2003, WinXP Microsoft SQL Server 2 ...

  6. 《SQL Server 2012 T-SQL基础》读书笔记 - 4.子查询

    Chapter 4 Subqueries 子查询分为:独立子查询(Self-Contained Subqueries)和相关子查询(Correlated Subqueries),独立子查询可以单独拿出 ...

  7. SQL Server 2012 OFFSET/FETCH NEXT分页示例(转载)

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

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

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

  9. Sql Server 2012 的新分页方法分析(offset and fetch) - 转载

    最近在分析 Sql Server 2012 中 offset and fetch 的新特性,发现 offset and fetch 无论语法的简洁还是功能的强大,都是相当相当不错的 其中 offset ...

随机推荐

  1. MySQL常用语句

    第1章 SQL结构化语言 1.什么是SQL? SQL,英文全称Structured Query Language,中文意思是结构化查询语言,它是一种关系型数据库中的数据进行定义和操作的语言方法,是大多 ...

  2. [转]表结构设计器EZDML介绍说明(包含修改配置文件,修改文本字段属性)

    超轻量级的表结构设计工具,这是一个数据库建表的小软件,可快速的进行数据库表结构设计,建立数据模型.类似大家常用的数据库建模工具如PowerDesigner.ERWIN.ER-Studio和Ration ...

  3. Unity仪表盘显示UGUI制作小心得

    最近在做设备仪表参数参数显示,由于模型摆放位置经常修改,加之要求不能在模型的下面添加东西,显示界面的位置也不得不跟着修改,一来二去就烦了,想了解决办法,现在总结如下: 1.仍然在模型下面新建Panel ...

  4. hibernate联合主键 注解方式

    转载自https://my.oschina.net/yotoo/blog/265571 方法一:主键类用@Embeddable,pojo类仍然用@Entity但是引用主键类的对象用@Id 主键pojo ...

  5. MySQL运算符和内置函数

    1.字符函数 CONCAT('a','-','b','-','c')效果等同于CONCAT_WS('-','a','b','c') FORMAT()的返回结果是字符型,会对操作数四舍五入,如:SELE ...

  6. 使用 Babel + React + Webpack 搭建 Web 应用

    话不说直接上正题. 环境搭建 Babel--目前浏览器对于ES6的语法解析支持度还不高,所以要通过转码在编译,所以在使用ES6之前要安装Babel,之前安装的时候遇到了一些问题但是没有全部记录下来,现 ...

  7. URi和Url格式

    1.主要的区别 url一定是有scheme. uri不一定有scheme,可以是相对和绝对的.(相对是依赖环境的) 2.uri的结构(3种划分) 1)[scheme:]scheme-specific- ...

  8. Java集合框架

    集合框架体系如图所示 Java 集合框架提供了一套性能优良,使用方便的接口和类,java集合框架位于java.util包中, 所以当使用集合框架的时候需要进行导包. Map接口的常用方法 Map接口提 ...

  9. mysql事务处理

    事务处理能保证所有的sql操作一次性完成或回滚,mysql默认的MyISAM表类型是不支持事务处理的,如果需要做事务处理,需要把表类型换成InnoDB <?php $dsn='mysql:hos ...

  10. alter system switch logfile与alter system archive log current的区别

    以前知道 ALTER SYSTEM SWITCH LOGFILE对单实例数据库或RAC中的当前实例执行日志切换, ALTER SYSTEM ARCHIVE LOG CURRENT会对数据库中的所有实例 ...