时间:2021-05-02
今天给大家介绍一下TOP、OFFSET-FETCH、SET ROWCOUNT用法笔记,希望对大家能有所帮助!
1、 TOP用法
语法格式:TOP ( expression ) [ PERCENT ] [ WITH TIES ]
用法:
表达式中指定返回的行数或百分比,则必须将表达式包含在括号内。用法如下:
注意:在未指定ORDER BY子句的情况下,TOP子句返回的数据行,是那些在物理循序上优先访问到的行,而并不一定是逻辑上的前几行。简单来说,这种返回结果具有不确定性。即使指定了ORDER BY子句,但是所指定的排序列中含有重复值,返回的结果也具有不确定性。不确定的数据,对于数据使用而言,没有多少价值。解决列中存在重复值时返回结果的不确定性问题,可以使用WITH TIES 关键字。该关键字将指定返回包含ORDER BY子句返回的最后一个值的所有行,这样将超过expression指定的数量。示例:
2、OFFSET-FETCH用法
SQL Server 2012版本引入了对OFFSET-FETCH技术的支持。OFFSET-FETCH筛选通常被视为ORDER BY子句的一部分,通常用于实现按顺序分页显示效果。OFFSET指定要跳过的行数,FETCH指定在跳过的行数后要筛选的行数用法:
注意:使用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的差别如下:
说明:TOP和OFFSET-FETCH性能要优于使用SET ROWCOUNT,应当尽量避免使用SET ROWCOUNT。用法:
原文地址:https://mp.weixin.qq.com/s/Om_2EJJ6_DZjvsfbFwO67A
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
PDO有一个函数PDOStatement::rowCount返回上一个SQL语句影响的行数。rowCount函数对于DELETE,INSERT,或者UPDATE
SQL Server2008提供了一个增强的SQL命令Merge,用法参看MSDN:http://msdn.microsoft.com/zh-cn/librar
PDOStatement::rowCountPDOStatement::rowCount—返回受上一个SQL语句影响的行数(PHP5>=5.1.0,PECLpd
1.character_set_server和collation_server这两个变量是服务器的字符集。在系统启动的时候可以通过--character-set
obj=$('div');//元素 h=obj.height();//元素高度 obj.offset().top;//元素距离顶部高度 wh=$(wi