SQL Server 2005 引入了 ROW_NUMBER()来提供一种容易的分页方式。

SQL Server 2012 添加了另外一种更简单高效的分页方式。

  1. /*
  2. 执行脚本去创建这个表并插入数据。
  3. */
  4. IF OBJECT_ID('Customers','U') IS NOT NULL
  5. DROP TABLE Customers
  6. CREATE TABLE Customers (
  7. CustomerID INT,
  8. CustomerNumber CHAR(4),
  9. CustomerName VARCHAR(50),
  10. CustomerCity VARCHAR(20) )
  11. GO
  12. INSERT INTO Customers (
  13. CustomerID, CustomerNumber, CustomerName, CustomerCity
  14. )
  15. SELECT
  16. Number,
  17. REPLACE(STR(Number, 4), ' ', '0'),
  18. 'Customer ' + STR(number,6),
  19. CHAR(65 + (number % 26)) + '-City'
  20. FROM master..spt_values WHERE type = 'p'
  21. AND number BETWEEN 0 AND 999
  22. /*
  23. 用ROW_NUMBER()的分页示例- SQL Server 2005/2008 版本。
  24. */
  25. DECLARE @page INT, @size INT
  26. SELECT @page = 3, @size = 10
  27. ;WITH cte AS (
  28. SELECT  TOP (@page * @size)
  29. CustomerID,
  30. CustomerName,
  31. CustomerCity,
  32. ROW_NUMBER() OVER(ORDER BY CustomerName ) AS Seq,
  33. COUNT(*) OVER(PARTITION BY '') AS Total
  34. FROM Customers
  35. WHERE CustomerCity IN ('A-City','B-City')
  36. ORDER BY CustomerName ASC
  37. )
  38. SELECT
  39. *
  40. FROM cte
  41. WHERE seq BETWEEN (@page - 1 ) * @size + 1 AND @page * @size
  42. ORDER BY seq
  43. /*
  44. SQL Server 2012中新添加的分页示例
  45. */
  46. DECLARE @page INT, @size INT
  47. SELECT @page = 3, @size = 10
  48. SELECT
  49. *,
  50. COUNT(*) OVER(PARTITION BY '') AS Total
  51. FROM Customers
  52. WHERE CustomerCity IN ('A-City','B-City')
  53. ORDER BY CustomerID
  54. OFFSET (@page -1) * @size ROWS
  55. FETCH NEXT @size ROWS ONLY;
  56. /*
  57. 同时执行这两个版本,打开执行计划,你可以注意到在这个例子中显著的性能差异。
  58. */

SQL Server 2012 OFFSET/FETCH NEXT分页示例(转载)的更多相关文章

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

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

  2. SQL Server 2012 列存储索引分析(转载)

    一.概述 列存储索引是SQL Server 2012中为提高数据查询的性能而引入的一个新特性,顾名思义,数据以列的方式存储在页中,不同于聚集索引.非聚集索引及堆表等以行为单位的方式存储.因为它并不要求 ...

  3. SQL Server使用Offset/Fetch Next实现分页

    T-SQL实现分页 ,查找指定范围内的数据 首先,正常的查询是这样的 使用分页后 select * from Products order by ProductID offset X rows fet ...

  4. SQL Server 2012使用Offset/Fetch Next实现分页

    在Sql Server 2012之前,实现分页主要是使用ROW_NUMBER(),在SQL Server2012,可以使用Offset ...Rows  Fetch Next ... Rows onl ...

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

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

  6. SQL Server 2012使用OFFSET/FETCH NEXT分页及性能测试

    最近在网上看到不少文章介绍使用SQL Server 2012的新特性:OFFSET/FETCH NEXT 实现分页.多数文章都是引用或者翻译的这一篇<SQL Server 2012 - Serv ...

  7. Sql Server 2012 分页方法分析(offset and fetch)

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

  8. SQLServer · 最佳实践 · SQL Server 2012 使用OFFSET分页遇到的问题

    1. 背景 最近有一个客户遇到一个奇怪的问题,以前使用ROW_NUMBER来分页结果是正确的,但是替换为SQL SERVER 2012的OFFSET...FETCH NEXT来分页出现了问题,因此,这 ...

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

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

随机推荐

  1. 序列化LinkedHashMap,有序输出Json字符串

    LinkedHashMap本身是有序的,使用JDK自带的序列化代码或者fastJson代码序列化后,字符串并非按照插入顺序输出 Map<String,String> linkedMap=n ...

  2. Common Pitfalls In Machine Learning Projects

    Common Pitfalls In Machine Learning Projects In a recent presentation, Ben Hamner described the comm ...

  3. GIT本地操作

    01. GIT简介(PPT) ================================================================================ 02. ...

  4. Redis 数据库

    Redis 服务器     Remote Dictionay Server     Redis是一个key-value持久化产品,通常被称为数据结构服务器.   Redis的key是string类型: ...

  5. centos 搭建gitlab

    #修改yum源 yum -y install wget cd /etc/yum.repos.d wget -O CentOS-Base.repo http://mirrors.aliyun.com/r ...

  6. apache配置多个虚拟主机

    设置apache 多个虚拟目录记录 #配置第2个虚拟目录<VirtualHost 127.0.0.2:80>ServerName www.xx.comDocumentRoot " ...

  7. SecureCRT光标颜色

    SecureCRT连linux光标一直没有,尤其是在vim编辑文档的时候特别麻烦,今天找出解决办法: 选项->会话选项->仿真:将ANSI颜色选中: 选项->会话选项->外观: ...

  8. 转<<C#集合Dictionary中按值的降序排列

    转载地址:http://blog.sina.com.cn/s/blog_5c5bc9070100pped.html C#集合Dictionary中按值的降序排列 static void Main(st ...

  9. 微信也能鉴别山寨iPhone【微信高级教程2】

    现在的技术真的很厉害,iPhone都能山寨几乎一样,外观不用说,系统UI都做得差不多相同,ytkah的一位朋友之前就被人骗了,她拿来手机让我优化,说是很卡,起初ytkah也琢磨很久,只是持怀疑态度,没 ...

  10. 完美串(区间dp)

    完美串 Description 爱美之心人皆有之,GG也不例外.所以GG他对于完美串有一种热衷的爱.在GG眼中完美串是一个具有无比魅力的01子串.这个子串有之其魅力之处,对它取反后水平翻转,它又和它原 ...