SQL中 ROWCOUNT和@@ROWCOUNT区别

ROWCOUNT sql

        做用:限定后面的sql在返回指定的行数以后便中止处理(查询 删除 更新都有效)spa

set rowcount 10            
select * from 表A            这样的查询只会返回表A中的前10条数据

注意,set rowcount 的设置会在整个会话中有效。要取消set rowcount的限定,只要在后面设置 set rowcount 0 就能够了code

同 top递归

从上面的示例来看,好像rowcount没有多大的用处,限制查询结果的数据,咱们使用top就能够了,并且还不用担忧若是忘记取消rowcount的设置而对后面的sql的影响table

ROWCOUNT  与 TOP的区别class

select  TOP  后面不能加参数,只能使用一个具体的int类型的数字cli

    select top 5
date

declare @n intselect

set @n=10sql语句

set rowcount @n

select * from 表A

@@ROWCOUNT

返回上次sql语句所影响的数据行数(查询  删除  更新)

select top 2 * from 表A

select @@Rowcount

那么,哪些地方咱们会用到@@Rowcount呢?

1、可能咱们见到@@Rowcount身影最多的地方是触发器中,好的触发器,通常都会在最前面加上if @@rowcount=0 return语句,好比:

create trigger ti_tablea on tablea after update

as

if @@rowcount=0 return

……


这样,若是tablea被修改的数据行数为0,那么触发器ti_tablea就会直接退出,而不用执行后面的代码了。


2、第二个可能用到的地方就是咱们能够使用@@rowcount来做递归或循环。好比下面示例:

declare @n int

set @n=1

select * from client_goods where id=@n


while @@rowcount>0

begin

set @n=@n+1

select * from client_goods where id=@n

end


这个示例是先查询client_goods中是否有id=1的数据,若是有,再查询是否有id=2的数据,一直查下去,直到id没有连续为止。固然你们在看这个


示例的时候不要考虑这个示例的意义,它只是说明了@@rowcount能够做为循环条件来用。

相关文章
相关标签/搜索