zoukankan      html  css  js  c++  java
  • SQL Server分页查询进化史

    分页查询一直SQL Server的一个硬伤,就是是经过一些进化,比起MySql的limit还是有一些差距。

    一、条件过滤(适应用所有版本)

    条件过滤的方法有很多,而思路就是利用集合的差集选择出目标集合以达到分页查询的效果,以下是最常见的一个思路

    SELECT TOP @PageSize * FROM TableName
    WHERE ID NOT IN (SELECT TOP (@PageSize * (@PageIndex - 1)) ID FROM TableName ORDER BY ID)
    ORDER BY ID

    @PageSize是指每页记录数

    @PageIndex是指页数

    TableName是要查询的表名

    ID一般是指主键,当然其他唯一值也是可以的, 如果不是唯一值分页结果就会不准确

    二、行序号(适应2005及以后版本)

    2005版本开始加入新指令,用来给行添加序号,而思路就是通过判断行序号来达到分页查询的效果

    SELECT TOP (@PageSize) *
    FROM (SELECT ROW_NUMBER() OVER(ORDER BY ID) AS RowIndex, * FROM TableName) NewTableName
    WHERE RowIndex>(@PageSize * (@PageIndex - 1))

    ROW_NUMBER() OVER(ORDER BY ID)是指按ID排序生成行序号

    RowIndex是行序号的列名

    NewTableName是包括行序号新表的表名

    PS:这种分页查询会有行序号

    三、排序分页参数(适应2012及以后版本)

    2012版本开始排序指令加入了新的参数,可以用来分页查询

    SELECT * FROM TableName
    ORDER BY ID
    OFFSET (@PageSize * (@PageIndex - 1)) ROWS
    FETCH NEXT (@PageSize) ROWS ONLY

    OFFSET是指跳过多少条记录,FETCH NEXT是指查询多少条记录。这种格式和EF里面的Skip和Take类似

  • 相关阅读:
    java中JSON转换
    使用Admin监控
    linux安装tomcat
    SpringBoot整合Redis
    linux6.8安装docker
    使用Actuator监控
    SpringBoot集成阿里巴巴Druid监控
    使用Log4j日志处理
    SpringBoot多数据源
    SpringBoot文件上传下载
  • 原文地址:https://www.cnblogs.com/TanSea/p/SqlServer-Paging-Query.html
Copyright © 2011-2022 走看看