SQL Server中變數的宣告和使用方法

2022-03-07 20:10:31 字數 3243 閱讀 4448

**:

宣告區域性變數語法:

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語句所影響的資料行數

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

set rowcount 10

select * from 表a

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

set rowcount 10

select * from 表a

goselect * 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主要是返回上次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

asif @@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可以作為迴圈條件來用。

SQL Server中變數的宣告和使用方法

sql server中變數的宣告和使用方法 宣告區域性變數語法 declare variable name datatype 其中 variable name為區域性變數的名稱,datatype為資料型別。給區域性變數賦值有兩種方法 1 set variable name value 2 selec...

SQL Server中變數的宣告和使用方法

宣告區域性變數語法 declare variable name datatype 其中 variable name為區域性變數的名稱,datatype為資料型別。給區域性變數賦值有兩種方法 1 set variable name value 2 select variable name value ...

sql server 變數宣告 設定 使用 輸出

本文面向對sql server中變數操作不熟悉的使用者,希望能使他們在看完本文後能對變數操作有具體和全面的認識。在學習sql server的過程中,很多時候需要對某些單獨的值進行除錯,這時就需要在sql server中對變數進行操作。變數能進行的操作分定義 賦值 使用三種,下面以一段簡短的 作為示例...