微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql – TOP与SET 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行

原文地址:https://www.jb51.cc/mssql/83444.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐