ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

SQLServer基础:TOP、OFFSET-FETCH、SET ROWCOUNT用法笔记

2021-05-28 17:56:37  阅读:376  来源: 互联网

标签:SET TOP 子句 SQLServer ROWCOUNT OFFSET FETCH


watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

今天给大家介绍一下TOP、OFFSET-FETCH、SET ROWCOUNT用法笔记,希望对大家能有所帮助!

1、 TOP用法

语法格式:

TOP ( expression ) [ PERCENT ] [ WITH TIES ]

  • expression:返回行数的数值表达式

  • PERCENT:指返回的结果集行的百分比。

用法:

--从UserInfo数据表提取20行记录SELECT TOP 20 * FROM UserInfo;--UserInfo数据表提取10%行记录SELECT TOP 10 PERCENT * FROM UserInfo;

表达式中指定返回的行数或百分比,则必须将表达式包含在括号内。用法如下:

DECLARE @n AS int;SET @n = 12SELECT TOP (@n) *FROM UserInfo ;

注意:在未指定ORDER BY子句的情况下,TOP子句返回的数据行,是那些在物理循序上优先访问到的行,而并不一定是逻辑上的前几行。

简单来说,这种返回结果具有不确定性。即使指定了ORDER BY子句,但是所指定的排序列中含有重复值,返回的结果也具有不确定性。不确定的数据,对于数据使用而言,没有多少价值。

解决列中存在重复值时返回结果的不确定性问题,可以使用WITH TIES 关键字。该关键字将指定返回包含ORDER BY子句返回的最后一个值的所有行,这样将超过expression指定的数量。

示例:

SELECT TOP 2 WITH TIES FROM UserInfoORDER BY CreateDate
2、OFFSET-FETCH用法

SQL Server 2012版本引入了对OFFSET-FETCH技术的支持。

OFFSET-FETCH筛选通常被视为ORDER BY子句的一部分,通常用于实现按顺序分页显示效果。OFFSET指定要跳过的行数,FETCH指定在跳过的行数后要筛选的行数

用法:

SELECT UserID, Birthday, Name,AgeFROM UserInfoORDER UserIDOFFSET 20 ROWS FETCH NEXT 15 ROWS ONLY;

注意:使用OFFSET-FETCH的查询必须具有ORDER BY子句。此外,FETCH子句也必须有OFFSET子句。如果不想跳过任何行,但是希望使用FETCH筛选,可以使用OFFSET 0 ROWS来表示。不过,单独使用FETCH表示跳过指定的行数,并返回查询结果中所有剩余行。

OFFSET-FETCH语法有一些有趣的语言方面需要注意。单数格式ROW和复数格式ROWS是可以互换的,因此能够以直观的类似英语方式来描述筛选。

例如,假设仅希望获取一行,如果指定了FETCH 1 ROWS,虽然这在语法上是有效的,不过看上去会很怪。因此,可以使用FETCH 1 ROW格式。此互换同样适用于OFFSET子句。另外,如果不希望跳过任何行(OFFSET 0 ROWS),可能觉得“first”比“next”更合适,因此,FIRST和NEXT格式是可以互换的。

从支持跳过功能看,OFFSET-FETCH子句比TOP子句更灵活。但OFFSET-FETCH不支持PERCENT和WITH TIES选项,而TOP支持。由于OFFSET-FETCH是标准的,而TOP不是,建议使用OFFSET-FETCH作为默认选择,除非你需要TOP支持且OFFSET-FETCH不支持的功能。

3、SET ROWCOUNT语句

SET ROWCOUNT n 语句限制结果集的大小,该语句指定在返回指定的n行后停止处理查询。SET ROWCOUNT与TOP的差别如下:

  • SET ROWCOUNT限制适用于计算ORDER BY后在结果集中生成行。如果指定了ORDER BY,SELECT语句将从分类排序后的某个值集中选择n行后结束。

  • TOP和OFFSET-FETCH适用于单个SELECT语句。直到执行下一个SET ROWCOUNT语句前,SET ROWCOUNT设置将一直有效。如果执行SET ROWCOUNT 0将关闭该选项。

说明:TOP和OFFSET-FETCH性能要优于使用SET ROWCOUNT,应当尽量避免使用SET ROWCOUNT。

用法:

SET ROWCOUNT 4;
SELECT TOP 20 *
FROM UserInfo;

IT技术分享社区

个人博客网站:https://programmerblog.xyz

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

文章推荐程序员效率:画流程图常用的工具程序员效率:整理常用的在线笔记软件远程办公:常用的远程协助软件,你都知道吗?51单片机程序下载、ISP及串口基础知识硬件:断路器、接触器、继电器基础知识

标签:SET,TOP,子句,SQLServer,ROWCOUNT,OFFSET,FETCH
来源: https://blog.51cto.com/u_11205641/2827128

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有