加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – TOP与SET ROWCOUNT

发布时间:2020-12-12 16:25:56 所属栏目:MsSql教程 来源:网络整理
导读:TOP和SET ROWCOUNT之间的性能是否存在差异,或者它们是否以相同的方式执行? 解决方法 是的,功能上他们是一回事.据我所知,两者之间没有明显的性能差异. 需要注意的一件事是,一旦设置了rowcount,这将在连接的生命周期中持续存在,因此请确保在完成连接后将其重置
TOP和SET ROWCOUNT之间的性能是否存在差异,或者它们是否以相同的方式执行?

解决方法

是的,功能上他们是一回事.据我所知,两者之间没有明显的性能差异.

需要注意的一件事是,一旦设置了rowcount,这将在连接的生命周期中持续存在,因此请确保在完成连接后将其重置为0.

编辑(发表马丁的评论)

SET ROWCOUNT的范围仅适用于当前过程.这包括当前程序调用的过程.它还包括通过EXEC或SP_EXECUTESQL执行的动态SQL,它们被视为“子”范围.

请注意,SET ROWCOUNT位于BEGIN / END范围内,但它超出了范围.

create proc test1
as
begin
    begin
    set rowcount 100
    end
    exec ('select top 101 * from master..spt_values')
end
GO

exec test1
select top 102 * from master..spt_values

结果= 100行,然后102行

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读