簡介:一個預存程序包括名字,參數列表,以及可以包括很多SQL語句的SQL語句集。
一個預存程序包括名字,參數列表,以及可以包括很多SQL語句的SQL語句集。
建立預存程序:
文法: CREATE PROCEDURE p() BEGIN /*此預存程序的本文*/ END |
CREATE PROCEDURE productpricing() BEGIN SELECT Avg(pro_price) AS priceaverage FROM products; END; # begin…end之間是預存程序的主體定義 # mysql的分界符是分號(;) |
調用預存程序的方法是:
# CALL加上過程名以及一個括弧 # 例如調用上面定義的預存程序 CALL productpricing(); # 哪怕是不用傳遞參數,預存程序名字後面的括弧“()”也是必須的 |
刪除預存程序的方法是:
DROP PROCUDURE productpricing; |
建立帶參數的預存程序:
CREATE PROCUDURE productpricing( OUT p1 DECIMAL(8,2), OUT ph DECIMAL(8,2), OUT pa DECIMAL(8,2) ) BEGIN SELECT Min(prod_price) INTO pl FROM products; SELECT Max(prod_price) INTO ph FROM products; SELECT Avg(prod_price) INTO pa FROM products; END; # DECIMAL用於指定參數的資料類型 # OUT用於表明此值是用於從預存程序裡輸出的 # MySQL支援 OUT, IN, INOUT |
調用帶參數的預存程序:
CALL productpricing(@pricelow, @pricehigh, @priceaverage); # 所有的參數必須以@開頭 # 要想擷取@priceaverage的值,用以下語句 SELECT @priceaverage; # 擷取三個的值,用以下語句 SELECT @pricehigh, @pricelow, @priceaverage; |
另一個帶IN和OUT參數的預存程序:
CREATE PROCEDURE ordertotal( IN onumber INT, OUT ototal DECIMAL(8,2) ) BEGIN SELECT Sum(item_price*quantity) FROM orderitems WHERE order_num = onumber INTO ototal; END; CALL ordertotal(20005, @total); SELECT @total; |
添加一個完整的例子: