sql server存儲過程語法

來源:互聯網
上載者:User

-- 變數的聲明,sql裡面聲明變數時必須在變數前加@符號
    DECLARE @I INT

-- 變數的賦值,變數賦值時變數前必須加set
    SET @I = 30

-- 聲明多個變數
    DECLARE @s varchar(10),@a INT

-- Sql 裡if語句
    IF 條件 BEGIN
        執行語句
    END
    ELSE BEGIN
        執行語句
    END
           
    DECLARE @d INT
    set @d = 1

    IF @d = 1 BEGIN

    -- 列印
        PRINT '正確'
    END
    ELSE BEGIN
        PRINT '錯誤'
    END

-- Sql 裡的多條件選擇語句.
    DECLARE @iRet INT, @PKDisp VARCHAR(20)
    SET @iRet = 1
    Select @iRet =
    CASE
        WHEN @PKDisp = '一' THEN 1
        WHEN @PKDisp = '二' THEN 2
        WHEN @PKDisp = '三' THEN 3
        WHEN @PKDisp = '四' THEN 4
        WHEN @PKDisp = '五' THEN 5
        ELSE 100
    END

-- 迴圈語句
    WHILE 條件 BEGIN   
        執行語句
    END

    DECLARE @i INT
    SET @i = 1
    WHILE @i<1000000 BEGIN
        set @i=@i+1
    END
    -- 列印
    PRINT @i

 

 

-- Select INTO 從一個查詢的計算結果中建立一個新表。 資料並不返回給用戶端,這一點和普通的
-- Select 不同。 新表的欄位具有和 Select 的輸出欄位相關聯(相同)的名字和資料類型。
       
        select * into NewTable
            from Uname

-- Insert INTO Select
        -- 表ABC必須存在
        -- 把表Uname裡面的欄位Username複製到表ABC
        Insert INTO ABC Select Username FROM Uname

-- 建立暫存資料表
        Create TABLE #temp(
            UID int identity(1, 1) PRIMARY KEY,
            UserName varchar(16),
            Pwd varchar(50),
            Age smallint,
            Sex varchar(6)
        )
        -- 開啟暫存資料表
        Select * from #temp

-- 預存程序
        -- 要建立預存程序的資料庫
        Use Test
        -- 判斷要建立的預存程序名是否存在
            if Exists(Select name From sysobjects Where name='csp_AddInfo' And

type='P')
            -- 刪除預存程序
            Drop Procedure dbo.csp_AddInfo
        Go
               
               
        -- 建立預存程序
        Create Proc dbo.csp_AddInfo
        -- 預存程序參數
        @UserName varchar(16),
        @Pwd varchar(50),
        @Age smallint,
        @Sex varchar(6)
        AS
        -- 預存程序語句體
        insert into Uname (UserName,Pwd,Age,Sex)
            values (@UserName,@Pwd,@Age,@Sex)
        RETURN
        -- 執行
        GO
               
        -- 執行預存程序
        EXEC csp_AddInfo 'Junn.A','123456',20,'男'

 

有關遊標的問題

        declare db cursor for       //聲明一個遊標(db為其名稱)

        SELECT UNIT_NAME FROM UNIT WHERE LEFT(UNIT_CODE,2)=LEFT(@strTO,2)//記錄集

        open db                 //打開遊標

            fetch next from db into @strUNIT_NAME //將第一個值放入一個參數中

        while @@fetch_status = 0 ---存在本筆值向下循環

(0:順利執行;-1:失敗,或資料列超出結果集;-2:擷取的資料列已遺漏)

        BEGIN             ----開始循環

                        //個體操作

        End                ----結束循環

        Close db            ---關閉遊標

deallocate db         //移除資料指標參考

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.