SQL Server中變量的聲明和使用方法


網址:http://blog.sina.com.cn/s/blog_63d0c97a0100qpy7.html

聲明局部變量語法:

DECLARE @variable_name DataType

其中 variable_name為局部變量的名稱,DataType為數據類型。

給局部變量賦值有兩種方法:

1、SET @variable_name=value

2、SELECT @variable_name=value

兩者的區別:SET賦值語句一般用於賦給變量一個指定的常量,SELECT賦值語句一般用於從表中查詢出數據然后賦給變量。

例如:

DECLARE @count int

SET @count=123

PRINT @count

 

declare @retCount int; //聲明一個變量@retCount
select @retCount = count(*) from TableA where Returned = 0 --將查詢到的count值賦值給變量@retCount

全局變量:

由於全局變量是系統定義的,我們這里只做舉例。

@@ERROR 最后一個T-SQL錯誤的錯誤號

@@IDENTITY 最后一次插入的標識值

@@LANGUAGE 當前使用的語言名稱

@@MAX_CONNECTIONS 可以創建的同時連接的最大數目

@@SERVERNAME 本地服務器的名稱

@@VERSION SQL Server的版本信息

@@rowcount 主要是返回上次sql語句所影響的數據行數

 

SQL Server中Rowcount與@@Rowcount的用法(http://www.lmwlove.com/ac/ID943)

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可以作為循環條件來用。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM