Sql Server 預存程序和觸發器

來源:互聯網
上載者:User

以前只是對概念的瞭解。沒有深入的瞭解。昨天在晚上找了一些資料學習學習。把自己的認識當做筆記記下來。做東西的時候,和資料庫打交道都是直接用sql語句拼接而成的,很少用預存程序和參數。

預存程序:儲存在資料庫中的一組T-SQL 陳述式,只需編譯一次, 在程式中就可以多次調用。 並且可以向語句中傳參數、輸出參數,防止注入攻擊,預存程序執行起來 效率更高、而且可以減少網路流量。

預存程序的定義文法:

  create procedure procedure_name [;number]

    (

      @parame1  data_type [output],

      ……

    )

  AS

    SQl語句

 

 

procedure_name :預存程序的名字

[;number] :是可選的整數,用來對同名的過程分組,以便用一條 DROP PROCEDURE 語句即可將同組的過程一起除去。例如,建立一組預存程序為 proc;1, proc;2 等。當要刪除這一組預存程序時就可以用DROP PROCEDURE orderproc 語句將除去整個組。

@parame:  定義參數的名稱

data_type: 定義參數的類型

output :選擇性參數,當在參數後面加上output限定時,指定該參數為返回的參數

 

 

觸發器:個人理解是,只針對一個表的insert、update、delete操作建立的,當執行相應操作時。會自動執行觸發器。

觸發器文法:

   create trigger 觸發器名稱

    on  表明

    for [insert | update | delete]

    as

    sql語句

 

觸發器和預存程序的區別:觸發器不需要在程式用調用。當對錶進行相應操作時會自動觸發;預存程序是實現編譯過,需要時在程式中直接調用

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.