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)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 息烽县| 富源县| 隆化县| 桐城市| 仪征市| 巫山县| 含山县| 黄梅县| 安西县| 浮梁县| 赣州市| 洪泽县| 灵宝市| 马鞍山市| 福泉市| 噶尔县| 郸城县| 济阳县| 温州市| 红桥区| 兴文县| 泗洪县| 沙雅县| 阳朔县| 临汾市| 南江县| 翼城县| 孝感市| 巴里| 济宁市| 嘉善县| 黔西县| 保定市| 南平市| 桃江县| 稻城县| 临夏市| 洛隆县| 晴隆县| 渝北区| 易门县|