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. 牛顿迭代法求n方根

    一.简单推导 二.使用 借助上述公式,理论上可以求任意次方根,假设要求a(假设非负)的n次方根,则有xn=a,令f(x)=xn-a,则只需求f(x)=0时x的值即可.由上述简单推导知,当f(x)=0时 ...

  2. 织梦DedeCMS首页调用单页文档内容的方法

    很多使用织梦dedecms单页文档功能的朋友都想知道如何在织梦首页调用单页文档的内容,下面就教大家具体的实现方法: 具体步骤如下: 首先在首页模板需要显示单页文档内容的地方插入如下代码: {dede: ...

  3. (转)CSS3 @font-face

    @font-face是CSS3中的一个模块,他主要是把自己定义的Web字体嵌入到你的网页中,随着@font-face模块的出现,我们在Web的开发中使用字体不怕只能使用Web安全字体,你们当中或许有许 ...

  4. jQuery.cookie.js

    一.jQuery.Cookie.js插件是一个轻量级的Cookie管理插件. 下载:http://github.com/carhartl/jquery-cookie/zipball/v1.4.1 特别 ...

  5. DedeCMS 5.7 后门漏洞

    简要描述: DedeCMS V5.7 SP1正式版 UTF-8 GBK版本疑似被植入一句话后门 前几日下载并不存在此代码 详细说明: shopcar.class.php被植入一句话@eval(file ...

  6. 可选择Email和用户名登录的代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. 实现JavaScript自定义函数的整合、链式调用及类的封装

    函数声明形式:表单验证函数 1 2 3 4 5 6 7 8 9 10 11 12 13 function checkName(){     console.log('检查用户名'); } functi ...

  8. UVALive 6124 Hexagon Perplexagon 题解

    http://vjudge.net/problem/viewProblem.action?id=37480 East Central Regional Contest Problem C: Hexag ...

  9. PHP函数之日期时间函数date()使用详解

    date()函数是我们在php开发中常碰到并且会使用到的一个日期函数,下面我来给大家介绍date()函数的一些基本扮靓和方法,有需要了解的朋友可进入参考   日期时间函数是PHP 的核心组成部分.无需 ...

  10. java笔记--查看和修改线程名称

    查看和修改线程名称 --如果朋友您想转载本文章请注明转载地址"http://www.cnblogs.com/XHJT/p/3893797.html  "谢谢-- java是一种允许 ...