日期:2014-05-19  浏览次数:20776 次

这四句代码看不明白,请老师们讲讲,谢谢啊!
declare   @num   int,@sqls   nvarchar(4000)  
set   @sqls= 'select   @a=count(*)   from   gzda '  
exec   sp_executesql   @sqls,N '@a   int   output ',@num   output  
select   @num  

我不明白的是   @a参数,@num参数的这种写法是什么意思呀,帮助也看了,不明白。

------解决方案--------------------

Transact-SQL 程式語法的參考說明


sp_executesql
執行可以重新使用許多次或已經動態建立的 Transact-SQL 陳述式或批次。Transact-SQL 陳述式或批次可以包含內嵌參數。

語法
sp_executesql [@stmt =] stmt
[
{, [@params =] N '@parameter_name data_type [,...n] ' }
{, [@param1 =] 'value1 ' [,...n] }
]

引數
[@stmt =] stmt

包含 Transact-SQL 陳述式或批次的 Unicode 字串。stmt m 必須是 Unicode 常數或可以以隱含方式轉換為 ntext 的變數。更複雜的 Unicode 運算式是不允許的 (例如以 + 運算子串連二個字串),也不允許字元常數。如果指定常數,其前置字元必須是 N,例如,Unicode 常數 N’sp_who’ 是合法的,但字元常數 ‘sp_who’ 是不合法的。字串的大小僅受限於可用資料庫伺服器記憶體。

stmt 可以包含與變數名稱相同形式的參數,例如:

N 'SELECT * FROM Employees WHERE EmployeeID = @IDParameter '

stmt 中包括的每個參數必須在 @params 參數定義清單與參數值清單中都有對應的項目。

[@params =] N '@parameter_name data_type [,...n] '

包含嵌入 stmt 的所有參數之定義的字串。字串必須是 Unicode 常數或可以以隱含方式轉換為 ntext 的變數。每個參數定義包含一個參數名稱與資料型別。n 是指出額外參數定義的替代符號 (Placeholder)。stmt 中指定的每個參數都必須在 @params中定義。如果 stmt 中的 Transact-SQL 陳述式或批次不包含參數,就不需要 @params。參數的預設值為 NULL。

[@param1 =] 'value1 '

參數字串中定義的第一個參數值。這個值可以是常數或變數。stmt 中包括的每個參數都必須有參數值。如果 stmt 中的 Transact-SQL 陳述式或批次沒有參數,就不需要參數值。

n

額外參數值的替代符號。值可以只是常數或變數。值不可以是函數或使用運算子建立的運算式等較複雜的運算式。

傳回碼值
0 (成功) 或 1 (失敗)

結果集
從內建在 SQL 字串的所有 SQL 陳述式傳回結果集。

備註
在批次、名稱範圍與資料庫內容方面,sp_executesql 與 EXECUTE 的行為相同。直到執行 sp_executesql 陳述式之後,系統才會編譯 sp_executesql stmt 參數中的 Transact-SQL 陳述式與批次。系統接著編譯與執行 stmt 的內容,此執行計劃與呼叫 sp_executesql 的批次執行計劃分開執行。sp_executesql 批次無法參照呼叫 sp_executesql 的批次中宣告的變數。呼叫 sp_executesql 的批次看不到 sp_executesql批次中的區域指標或變數。資料庫內容的變更只會持續到 sp_executesql 陳述式的結尾。

當陳述式中只變更參數值時,sp_executesql 可以用來替代預存程序來重覆執行 Transact-SQL 陳述式。因為 Transact-SQL 陳述式本身維持不變,只有參數值變更,Microsoft® SQL Server™ 查詢最佳化器可能會重覆使用第一次執行時產生的執行計劃。


附註 如果陳述式字串中的物件名稱不完整,就不會重覆使用執行計劃。


sp_executesql 支援參數值與 Transact-SQL 字串分開設定:

DECLARE @IntVariable INT
DECLARE @SQLString NVARCHAR(500)
DECLARE @ParmDefinition NVARCHAR(500)

/* Build the SQL string once.*/
SET @SQLString =
N 'SELECT * FROM pubs.dbo.employee WHERE job_lvl = @level '
SET @ParmDefinition = N '@level tinyint '
/* Execute the string with the first parameter value. */
SET @IntVariable = 35
EXECUTE sp_executesql @SQLString, @ParmDefinition,
@level = @IntVariable
/* Execute the same string with the second parameter value. */
SET @IntVariable = 32
EXECUTE sp_executesql @SQLString, @ParmDefinition,
@level = @IntVariable

在 sp_executesql 中能變更參數的功能可以提供以下使用 EXECUTE 陳述式來執行字串的優點:

因為 sp_executesql 字串中 Transact-SQL 陳述式的實際文字在不同執行之間不會變更,查詢最佳化器可能會將第二次執行的 Transact-SQL 陳述式與第一次執行時產生的執行計劃比較。因此,SQL Server 不需要編譯第二個陳述式。


只建立一次 Transact-SQL 字串。


在其原生 (Native) 格式中指定整數參數。不需要轉換為 Unicode。
權限
執行權限預設授予 public 角色。

範例
A. 執行簡單的 SELECT 陳述式
以下範例建立並執行一個簡單的 SELECT 陳述式,其中包含命名為 @level 的內嵌參數。

execute sp_executesql
N 'select * from pubs.dbo.employee where job_lvl = @level ',
N '@level tinyint ',
@level = 35

B. 執行動態建立的字串
以下範例顯示使用 sp_execut