mysql編寫存儲過程(1)


存儲過程:其實就是存儲在數據庫中,有一些邏輯語句與SQL語句組成的函數。由於是已經編譯好的語句,所以執行速度快,而且也安全。

打開mysql的控制台,開始編寫存儲過程。

實例1:

編寫存儲過程:

執行存儲過程:

查看執行結果:

 

語句解釋:

1、delimiter //  ,聲明分隔符:DELIMITER是分割符的意思,因為MySQL默認以";"為分隔符,如果我們沒有聲明分割符,那么編譯器會把存儲過程當成SQL語句進行處理,則存儲過程的編譯過程會報錯,所以要事先用DELIMITER關鍵字申明當前段分隔符,這樣MySQL才會將";"當做存儲過程中的代碼,不會執行這些代碼(這里如果不懂的話,你可以通過試錯的方法來理解)。

2、編寫存儲過程的格式:CREATE PROCEDURE([[IN |OUT |INOUT ] 參數名 數據類形...])

例子:

  1)create procedure proc1(out s int)  // 只有輸出

  2)create procedure proc2(in p_in bigint)  // 只有輸入

  3)create procedure proc15() // 沒有輸入與輸出

  4)create procedure demo_multi_param(in id bigint,in name varchar(32),out c int) //多輸入與輸出

3、過程體的開始與結束使用BEGIN與END進行標識。

4、select count (*) into s from student; // 過程體,一系列的邏輯語句,sql語句

5、delimiter ; 用完了之后要把分隔符還原。

實例2:

實例3、

結論:輸出參數在過程中改變了,會得到保存。但是如果@p_out有預設的值,執行存儲過程也不會認預設值,可以從第一個輸出為null看出。

實例4、

 注意:p_in雖然在存儲過程中被修改,但並不影響@p_id的值,執行完語句之后,再執行@select @p_in。

實例5、

結論:如果輸入輸出參數,那么在存儲過程中,即會認輸入的,如果在存儲過程中改變了,那么輸出也會認。

實例6:

這個是一個多個輸入,一個輸出的例子。

實例7:

說明:begin...end 之間是內部變量的作用域,一旦超過這個作用域,其內部聲明的變量就結束了,就會變成外部作用域的變量。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM