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 閱讀(1821) 評論(0)  編輯  收藏 所屬分類: 數據庫

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

          導航

          統計

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 靖边县| 闽清县| 华池县| 德格县| 天门市| 河曲县| 太白县| 仪征市| 昭苏县| 青河县| 广丰县| 汉源县| 格尔木市| 商河县| 龙泉市| 扎囊县| 盐源县| 双辽市| 通城县| 望奎县| 土默特左旗| 章丘市| 五河县| 乐东| 贡山| 临桂县| 正蓝旗| 清原| 青川县| 徐州市| 田东县| 巴彦淖尔市| 正宁县| 石狮市| 罗甸县| 称多县| 文成县| 洪湖市| 邓州市| 布拖县| 通江县|