天天看點

SQL Server中Rowcount與@@Rowcount

rowcount的用法

  rowcount的作用就是用來限定後面的sql在傳回指定的行數之後便停止處理,比如下面的示例,

set rowcount 10
select * from 表A
      

  這樣的查詢隻會傳回表A中的前10條資料。它和 "select top 10 * from 表A" 的作用一樣。注意一點,set rowcount 的設定會在整個會話中有效。比如下面的sql示例:

set rowcount 10
select * from 表A
go
select * from 表B
      

  表A和表B都隻會傳回前10條資料。

  要取消set rowcount的限定,隻要設定 set rowcount 0 就可以了。

  從上面的示例來看,好像rowcount沒有多大的用處,限制查詢結果的資料,我們使用top就可以了,而且還不用擔心如果忘記取消rowcount的設定而對後面的sql的影響。 但在下面的情況下,rowcount的設定就會給我們帶來很大的友善哦。

  我們都知道select top 後面不能加參數,隻能使用一個具體的int類型的數字。如果我們想實作top後面跟參數的功能,就隻有構造sql字元串,然後使用exec來執行了。比如:

declare @n int
declare @sql nvarchar(1000)
set @n=10
set @sql='select top '+cast(@n as varchar(10))+' * from 表A'
exec(@sql)
      

  先不說上面語句中exec的性能,單從sql的可讀性上來看就很不友好。但如果我們使用rowcount來解決,就顯的很優雅了,因為set rowcount後面是可以使用參數的。示例如下:

declare @n int
set @n=10
set rowcount @n
select * from 表A
      

  注意:set rowcount的限定對修改,删除一樣有效。比如下面的示例:

set rowcount 10
update 表a set qty=10 where id<100
      

  這樣,上面語句最多隻會修改表a中id<100的前10條資料(假設id<100的資料數量大于10)

  删除也是一樣

set rowcount 10
delete from 表a
      

  這樣,上面的語句最多隻會删除表a中前10條資料

  @@Rowcount的用法

  @@Rowcount與Rowcount看起來很像,隻相差了兩個@,但它們的功能是不一樣的,@@Rowcount主要是傳回上次sql語句所影響的資料行數,比如:

select top 2 * from 表A
select @@Rowcount
      

  如果表A中的資料量大于或等于2,那麼select @@Rowcount就會傳回2,如果隻有1條或0條資料,那麼select @@Rowcount就會傳回1或者0

  注意,不要把@@Rowcount了解為隻傳回查詢的結果數量,删除,修改,新增等語句,也會正确的傳回@@Rowcount值。比如:

update 表A set gid='a' where gid='a'
select @@Rowcount
      

  如果表A中存在gid='a'的資料,那麼select @@Rowcount就會傳回它所修改資料的行數,如果不存在gid='a'的資料,那麼select @@Rowcount就會傳回0,删除與新增都是同樣。

  那麼,哪些地方我們會用到@@Rowcount呢?

  一、可能我們見到@@Rowcount身影最多的地方是觸發器中,好的觸發器,一般都會在最前面加上if @@rowcount=0 return語句,比如:

create trigger ti_tablea on tablea after update
as
if @@rowcount=0 return
……
      

  這樣,如果tablea被修改的資料行數為0,那麼觸發器ti_tablea就會直接退出,而不用執行後面的代碼了。

  二、第二個可能用到的地方就是我們可以使用@@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可以作為循環條件來用。