qileilove

          blog已經轉移至github,大家請訪問 http://qaseven.github.io/

          存儲過程中拼接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 閱讀(1822) 評論(0)  編輯  收藏 所屬分類: 數據庫

          <2012年5月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          導航

          統計

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 文昌市| 琼结县| 顺平县| 呼和浩特市| 太仓市| 措勤县| 克什克腾旗| 焦作市| 依安县| 阿克苏市| 寿光市| 井陉县| 丹棱县| 苗栗市| 贵港市| 灵武市| 河曲县| 庆云县| 香河县| 清徐县| 辛集市| 忻城县| 罗源县| 曲靖市| 察隅县| 泰安市| 新化县| 报价| 长白| 哈密市| 雷波县| 新野县| 江源县| 金塔县| 津市市| 公主岭市| 乃东县| 昌图县| 金阳县| 榆树市| 双桥区|