扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
临近春节,心早已飞了不在工作上了,下面小编给大家整理些数据库的几种分页查询。
我们提供的服务有:成都网站设计、成都做网站、微信公众号开发、网站优化、网站认证、沙县ssl等。为千余家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的沙县网站制作公司
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
rownumberfirstIndex;
例如:
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
rownumber40
结果:
这两个方法,就仅仅是多了一列
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
rownumber40
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()解析函数的不同,希望对大家有所帮助。
没有区别个人的习惯 在SQLServer2000中top后只可以跟常数,在2005后可以跟变量了
也许唯一的区别就是top(Expression)括号中可以跟表达式
top是指按顺序选取前几个数据。order
by是属性默认升序排列(asc),如果想倒序+desc
select
*和select
all
select
1一样是选取所有(任意一个)
top
3前3个
select
查询表达式是+表中的元组中的候选码
select
no
from
no是table表中的一个码,就是唯一标示这一元组的名字,额
就是名字
不能直接用select+数字
只能用select
123
as
no
SQL SELECT TOP 子句用于规定要返回的记录的数目,对于拥有数千条记录的大型表来说,是非常有用的。
from 树懒学堂-免费的数据学习平台
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流