存儲過程中拼接SQL語句
很多時候我們需要利用參數在存儲過程中重新組織SQL語句,在存儲過程中拼接的SQL語句只是一個字符串,不會被直接執行,所以加一個execute執行它就可以了。具體看如下演示代碼:
代碼:
set ANSI_NULLS ON set QUOTED_IDENTIFIER ON go -- ============================================= -- Author: yy -- Create date: 2012-1-17 -- Description: 存儲過程SQL字符串拼接示例 -- ============================================= CREATE PROCEDURE [dbo].[Test] @FileName varchar(10), --字段名 @Operator varchar(1), --操作符 @FileValue varchar(10) --字段值 AS DECLARE @TempSql varchar(100) --臨時存放sql語句 BEGIN set @TempSql= 'select * from Comment where ' + @FileName + @Operator + char(39) + @FileValue + char(39) --拼接sql字符串,char(39)為單引號 execute(@TempSql) --執行sql字符串 END |
測試:
execute Test 'newsid','>',4 |
在這解釋一下“ALTERPROCEDURE [dbo].[Test]”至“AS”之間的代碼和“AS”至“BEGIN”之間的代碼有什么區別,像我這種SQL新手應該會有疑問:為什么@TempSql要定義在“AS”至“BEGIN”之間?因為,“AS”至“BEGIN”之間定義的為臨時變量,前邊必須加DECLARE,和其他語言中普通變量的使用方法相同;而“ALTER PROCEDURE [dbo].[Test]”至“AS”之間定義的是存儲過程被調用時傳入的必要參數,必須在調用的時候就賦值,不可以加DECLARE,可以理解為字符常量,一旦調用時被賦值,就再無法改變,就上邊例子來說,類似@FileName=’xxx’的寫法是錯誤的。因為@TempSql只是用來接受SQL語句的臨時變量,沒有初值,但必須接受值,所以要定義在“AS”至“BEGIN”之間。
posted on 2012-05-31 09:56 順其自然EVO 閱讀(1821) 評論(0) 編輯 收藏 所屬分類: 數據庫