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行