sql語句需要先編譯然後執行,而儲存過程是一組為了完成特定功能的sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數(如果該儲存過程帶有引數)來呼叫它。
儲存過程是可程式設計的函式,在資料庫中建立並儲存,可以由sql語句和控制結構組成。當想要在不同的應用程式或平台上執行相同的函式,或者封裝特定功能時,儲存過程是非常有用的。資料庫中的儲存過程可以看做是對程式設計中物件導向方法的模擬,它允許控制資料的訪問方式。
1. 增強sql語句的功能和靈活性:儲存過程可以用控制語句編寫,有很強的靈活性,可以完成複雜的判斷和較複雜的運算。
2. 標準元件式程式設計:儲存過程被建立後,可以在程式中被多次呼叫,而不必重新編寫該儲存過程中的sql語句。而資料庫專業人員可以隨時對儲存過程進行修改,對應用程式源**毫無影響。
3. 較快的執行速度:如果某一操作包含大量的transaction-sql**或分別被多次執行,那麼儲存過程要比批處理的執行速度快很多。因為儲存過程是預編譯的。在首次執行乙個儲存過程時查詢,優化器對其進行分析優化,並且給出最終被儲存在系統表中的執行計畫。而批處理的transaction-sql語句在每次執行時都要進行編譯和優化,速度相對要慢一些。
4. 減少網路流量:針對同乙個資料庫物件的操作(如查詢、修改),如果這一操作所涉及的transaction-sql語句被組織進儲存過程,那麼當在客戶計算機上呼叫該儲存過程時,網路中傳送的只是該呼叫語句,從而大大減少網路流量並降低了網路負載。
5. 作為一種安全機制來充分利用:通過對執行某一儲存過程的許可權進行限制,能夠實現對相應的資料的訪問許可權的限制,避免了非授權使用者對資料的訪問,保證了資料的安全。
語法:
createprocedure過程名 ( [ in | out | inout ] 引數名 資料型別) [特性 ...] 過程體
分隔符:mysql預設以";"為分隔符,如果沒有宣告分割符,則編譯器會把儲存過程當成sql語句進行處理,因此編譯過程會報錯,所以要事先用「delimiter //」宣告當前段分隔符,讓編譯器把兩個"//"之間的內容當做儲存過程的**,不會執行這些**;「delimiter ;」的意為把分隔符還原。delimiter //create procedure myproc(out s int)
begin
select count(*) into s from students;
end//
delimiter ;
過程體:
過程體的開始與結束使用begin與end進行標識。
引數:
儲存過程根據需要可能會有輸入、輸出、輸入輸出引數,如果有多個引數用","分割開。mysql儲存過程的引數用在儲存過程的定義,共有三種引數型別,in,out,inout:
in:引數的值必須在呼叫儲存過程時指定,在儲存過程中修改該引數的值不能被返回,為預設值。
out:該值可在儲存過程內部被改變,並可返回
inout:呼叫時指定,並且可被改變和返回
in引數例子:
執行結果:delimiter //create procedure in_param(in p_in int)
begin
select p_in;
set p_in=2;
select p_in;
end;
//delimiter ;
#呼叫set @p_in=1;call in_param(@p_in);
select @p_in;
以上可以看出,p_in雖然在儲存過程中被修改,但並不影響@p_id的值。
out引數例子:
執行結果:#儲存過程out引數delimiter //
create procedure out_param(out p_out int)
begin
select p_out;
set p_out=2;
select p_out;
end;
//delimiter ;
#呼叫set @p_out=1;
call out_param(@p_out);
select @p_out;
inout引數例子:
執行結果:#儲存過程inout引數delimiter //
create procedure inout_param(inout p_inout int)
begin
select p_inout;
set p_inout=2;
select p_inout;
end;
//delimiter ;
#呼叫set @p_inout=1;
call inout_param(@p_inout) ;
select @p_inout;
MySQL儲存過程詳解 mysql 儲存過程
儲存過程簡介 我們常用的運算元據庫語言sql語句在執行的時候需要要先編譯,然後執行,而儲存過程 stored procedure 是一組為了完成特定功能的sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數 如果該儲存過程帶有引數 來呼叫執行它。乙個儲存過程是乙個可程式設計的...
MySQL儲存過程詳解
我們常用的運算元據庫語言sql語句在執行的時候需要要先編譯,然後執行,而儲存過程 stored procedure 是一組為了完成特定功能的sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數 如果該儲存過程帶有引數 來呼叫執行它。乙個儲存過程是乙個可程式設計的函式,它在資料...
mysql儲存過程詳解
儲存過程procedure是一組為了完成特定功能的sql語句集合,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名稱並給出引數來執行。儲存過程中可以包含邏輯控制語句和資料操縱語句,它可以接受引數 輸出引數 返回單個或多個結果集以及返回值。由於儲存過程在建立時即在資料庫伺服器上進行了編譯並儲存在資料...