SQLSERVER分页查询关于使用Top方式和row_number()解析函数的不同

 更新时间:2016年02月03日 15:39:54   作者:Eric-Lee  
这篇文章主要介绍了SQLSERVER分页查询关于使用Top方式和row_number()解析函数的不同的相关资料,需要的朋友可以参考下

临近春节,心早已飞了不在工作上了,下面小编给大家整理些数据库的几种分页查询。

Sql Sever 2005之前版本:

select top 页大小 *
from 表名
where id not in
(
select top 页大小*(查询第几页-1) id from 表名 order by id
)
order by id 

例如:

select top 10 * --10 为页大小
from [TCCLine].[dbo].[CLine_CommonImage]
where id not in
(
--40是这么计算出来的:10*(5-1)
-- 页大小*(查询第几页-1)
select top 40 id from [TCCLine].[dbo].[CLine_CommonImage] order by id
)
order by id

结果为:

Sql Sever 2005及以上版本,多了个分页查询方法:

/*
* firstIndex:起始索引
* pageSize:每页显示的数量
* orderColumn:排序的字段名
* SQL:可以是简单的单表查询语句,也可以是复杂的多表联合查询语句
*/
select top pageSize o.* from (select row_number() over(order by orderColumn) as rownumber,* from(SQL) as o where rownumber>firstIndex; 

例如:

select top 10 numComImg.* from 
( select row_number() over(order by id asc) as rownumber,* from (select * FROM [TCCLine].[dbo].[CLine_CommonImage]) as comImg)
as numComImg where rownumber>40 

结果:

这两个方法,就仅仅是多了一列 rewnumber 吗?当然不是,来看下内部差别吧:

在两个SQL上,分别加入以下SQL,并使用MS的“包括执行计划”,便于查看执行详情:

SET STATISTICS TIME ON
GO 

要执行的SQL:

SET STATISTICS TIME ON
GO
select top 10 numComImg.* from 
( select row_number() over(order by id asc) as rownumber,* from (select * FROM [TCCLine].[dbo].[CLine_CommonImage]) as comImg)
as numComImg where rownumber>40
SET STATISTICS TIME ON
GO
select top 10 * --10 为页大小
from [TCCLine].[dbo].[CLine_CommonImage]
where id not in
(
--40是这么计算出来的:10*(5-1)
-- 页大小*(查询第几页-1)
select top 40 id from [TCCLine].[dbo].[CLine_CommonImage] order by id
)
order by id 

执行之后,查看执行计划:

看得出,两个同样功能的SQL,执行时,使用 row_number() 的,要比是用 纯TOP方式的,查询开销少得多,上图显示 28:72,纯top方式,使用了两次聚集扫描。

再来看下执行时间信息:

row_number()方式的:


纯top方式:


相比之下,还是row_number()解析函数效率比较高写。

以上所述是小编给大家分享的SQLSERVER分页查询关于使用Top方式和row_number()解析函数的不同,希望对大家有所帮助。

相关文章

  • SQL Server 触发器详情

    SQL Server 触发器详情

    这篇文章主要介绍了SQL Server 触发器,触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程。触发器主要是通过事件进行触发被自动调用执行的。而存储过程可以通过存储过程的名称被调用。需要的朋友可以参考一下
    2021-09-09
  • SQL SERVER 触发器介绍

    SQL SERVER 触发器介绍

    触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程。触发器主要是通过事件进行触发被自动调用执行的。而存储过程可以通过存储过程的名称被调用。
    2013-03-03
  • sql 批量修改数据库表

    sql 批量修改数据库表

    通过sysobjects和syscolumns系统表,找到每个表的每个列,如果列类型是字符串类型的,比如varchar、nvarchar等,利用游标,对这些列进行更新。
    2009-01-01
  • SqlServer 巧妙解决多条件组合查询

    SqlServer 巧妙解决多条件组合查询

    开发中经常会遇得到需要多种条件组合查询的情况,比如有三个表,年级表Grade(GradeId,GradeName),班级Class(ClassId,ClassName,GradeId),学员表Student(StuId,StuName,ClassId),现要求可以按年级Id、班级Id、学生名,这三个条件可以任意组合查询学员信息
    2012-11-11
  • SQL Server解析XML数据的方法详解

    SQL Server解析XML数据的方法详解

    这篇文章主要介绍了SQL Server解析XML数据的方法,结合实例形式详细分析了SQL Server针对xml数据的读取,遍历,删除,查找等常用操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-06-06
  • distinct 多列问题结合group by的解决方法

    distinct 多列问题结合group by的解决方法

    distinct 多列问题 group by 解决
    2010-06-06
  • SQLSERVERAGENT警告:事件 ID: 312

    SQLSERVERAGENT警告:事件 ID: 312

    这篇文章主要介绍了SQLSERVERAGENT警告:事件 ID: 312,信息:事件 ID: 311,错误:事件 ID: 318,需要的朋友可以参考下
    2014-12-12
  • Windows Server2008 R2 MVC 环境安装配置教程

    Windows Server2008 R2 MVC 环境安装配置教程

    这篇文章主要为大家详细介绍了Windows Server2008 R2 MVC 环境安装配置教程,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 探讨Sql Server中的declare基本知识

    探讨Sql Server中的declare基本知识

    这篇文章主要探讨Sql Server中的declare基本知识,实战探讨主要来源于触发器的Demo,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-07-07
  • sqlserver四舍五入使用round函数及cast和convert函数

    sqlserver四舍五入使用round函数及cast和convert函数

    大家在遇到sqlserver四舍五入除了用round函数还有没有其他方法呢?下面小编给大家介绍使用cast和convert函数,感兴趣的朋友一起学习吧
    2015-11-11

最新评论