(1) 經過把處理封裝在容易使用的單元中,簡化複雜操做mysql
(2) 爲了保證數據的完整性,不要求反覆創建一系列的處理操做,全部開發人員和應用程序都使用同一(試驗和測試)存儲過程,則所使用的代碼否的相同的,這一點的延申就是爲了防止錯誤,保證數據的一致性sql
(3)提升性能,由於使用存儲過程比使用單獨的SQL語句要快安全
(4)存儲功能能夠編寫功能更強更靈活的代碼性能
一句話,既簡單、安全又高性能測試
create procedure product_price() begin select Avg(proc_price) as priceaverage from products; end;
調用:spa
call product_price()命令行
輸出:3d
是否是很簡單,下面使用返回值建立存儲過程code
drop procedure product_price; create procedure product_price( OUT pa decimal(8,2) ) begin select Avg(proc_price) into pa from products; end; call product_price(@priceaverge); select @priceaverge
下面是參數和返回值建立存儲過程blog
drop procedure IF EXISTS product_price; create procedure product_price( IN number int, OUT sum decimal(8,2) ) begin select Sum(proc_price) into sum from products where vend_id = number; end; call product_price(1003, @pricesum); select @pricesum;
使用先前建立的orderitems表
需求:
經過order_num計算該訂單號的產品總價,再根據是否交稅狀況返回最終價格
create procedure orderprice( in ordernum int, in istax boolean, out sumprice decimal(8,2) ) begin declare taxrate int default 6; select Sum(quantity * item_price) into sumprice from orderitems where order_num = ordernum; if istax then select sumprice+(sumprice*taxrate/100) into sumprice; end if; end;
測試:
call orderprice(20005,0,@sumprice); select @sumprice;
call orderprice(20005,1,@sumprice); select @sumprice;
因爲mysql命令行使用;做爲語句分隔符,若是命令行要解析存儲過程的;字符,則它們最終不會成爲存儲過程的成分,這會使存儲過程當中的sql出現句法錯誤。
能夠採用下列方法進行解決:
DELIMITER // create procedure product_price() begin select Avg(proc_price) as priceaverage from products; end // DELIMITER ;
DELIMITER // 告訴命令行實用程序使用//做爲新的語句結束分隔符,最後再還原爲DELIMITER ;