存儲過程:其實就是存儲在數據庫中,有一些邏輯語句與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 之間是內部變量的作用域,一旦超過這個作用域,其內部聲明的變量就結束了,就會變成外部作用域的變量。
