MySql必知必會實戰練習(五)存儲過程

1. 爲何使用存儲過程?

(1) 經過把處理封裝在容易使用的單元中,簡化複雜操做mysql

(2) 爲了保證數據的完整性,不要求反覆創建一系列的處理操做,全部開發人員和應用程序都使用同一(試驗和測試)存儲過程,則所使用的代碼否的相同的,這一點的延申就是爲了防止錯誤,保證數據的一致性sql

(3)提升性能,由於使用存儲過程比使用單獨的SQL語句要快安全

(4)存儲功能能夠編寫功能更強更靈活的代碼性能

  一句話,既簡單、安全又高性能測試

2. 建立存儲過程

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;

3. 複雜存儲過程展現

  使用先前建立的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;

4. 對於使用mysql命令行進程存儲操做的補充

  因爲mysql命令行使用;做爲語句分隔符,若是命令行要解析存儲過程的;字符,則它們最終不會成爲存儲過程的成分,這會使存儲過程當中的sql出現句法錯誤。

  能夠採用下列方法進行解決:

DELIMITER //
create procedure product_price()
begin
    select Avg(proc_price) as priceaverage
    from products;
end //
DELIMITER ;

  DELIMITER // 告訴命令行實用程序使用//做爲新的語句結束分隔符,最後再還原爲DELIMITER ;

相關文章
相關標籤/搜索