mysql資料庫 儲存過程

2021-09-03 07:58:29 字數 2556 閱讀 4859

類似於 「函式」,是一組為了完成特定功能的sql語句集,

第一次編譯,以後可以直接呼叫不需要再次編譯。(根據定義的不同需要傳入引數)

(1).增強sql語言的功能和靈活性:儲存過程可以用控制語句編寫,有很強的靈活性,可以完成複雜的判斷和較複雜的運算。

(2).標準元件式程式設計:儲存過程被建立後,可以在程式中被多次呼叫,而不必重新編寫該儲存過程的sql語句。而且資料庫專業人員可以隨時對儲存過程進行修改,對應用程式源**毫無影響。

(3).較快的執行速度:如果某一操作包含大量的transaction-sql**或分別被多次執行,那麼儲存過程要比批處理的執行速度快很多。因為儲存過程是預編譯的。在首次執行乙個儲存過程時查詢,優化器對其進行分析優化,並且給出最終被儲存在系統表中的執行計畫。而批處理的transaction-sql語句在每次執行時都要進行編譯和優化,速度相對要慢一些。

(4).減少網路流量:針對同乙個資料庫物件的操作(如查詢、修改),如果這一操作所涉及的transaction-sql語句被組織進儲存過程,那麼當在客戶計算機上呼叫該儲存過程時,網路中傳送的只是該呼叫語句,從而大大減少網路流量並降低了網路負載。

(5).作為一種安全機制來充分利用:通過對執行某一儲存過程的許可權進行限制,能夠實現對相應的資料的訪問許可權的限制,避免了非授權使用者對資料的訪問,保證了資料的安全。

create procedure過程名([[in|out|inout] 引數名 資料型別[,[in|out|inout] 引數名 資料型別…]]) [特性 ...] 過程體

delimiter //

create procedure myproc(out s int)

begin

select count(*) into s from students;

end//

delimiter ;

分隔符
mysql預設以";"為分隔符,如果沒有宣告分割符,則編譯器會把儲存過程當成sql語句進行處理,因此編譯過程會報錯,所以要事先用「delimiter //」宣告當前段分隔符,讓編譯器把兩個"//"之間的內容當做儲存過程的**,不會執行這些**;「delimiter ;」的意為把分隔符還原。

引數

儲存過程根據需要可能會有輸入、輸出、輸入輸出引數,如果有多個引數用","分割開。mysql儲存過程的引數用在儲存過程的定義,共有三種引數型別,in,out,inout:

過程體:

過程體的開始與結束使用begin與end進行標識。

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;

結果: 1          2              1

就是說:p_in 在儲存過程中被改變了,但是不影響原本的值。

#儲存過程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;
結果: 2                       2

#儲存過程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;

結果:1               2                 2

drop procedure [過程1[,過程2…]]
從mysql的**中刪除乙個或多個儲存過程。

八 資料庫mysql儲存過程

8.1什麼是儲存過程 儲存過程 帶有邏輯的sql語句 之前的sql沒有條件判斷,沒有迴圈 儲存過程帶上流程控制語句 if while 8.2儲存過程特點 1 執行效率非常快,儲存過程是在資料庫的伺服器端執行的!2 移植性很差!不同資料庫的儲存過程是不能移植 8.3儲存過程語法 建立儲存過程 deli...

MySQL資料庫儲存過程詳解

mysql資料庫儲存過程詳解 一 儲存過程 1 概念 儲存過程 stored procedure 是一種在資料庫中儲存複雜程式,以便外部程式呼叫的一種資料庫物件。儲存過程是為了完成特定功能的sql語句集,經編譯建立並儲存在資料庫中,使用者可通過指定儲存過程的名字並給定引數 需要時 來呼叫執行。儲存過...

資料庫MySQL之儲存過程

儲存過程是一種在資料庫中儲存複雜程式,以便外部程式呼叫的一種資料庫物件。其在思想上與物件導向程式設計中函式的定義與呼叫一致,儲存過程只是sql語言維度上的封裝與運用。優點 1 簡化了儲存呼叫者的步驟,降低了儲存呼叫者的學習成本 2 隱藏了儲存過程的實際邏輯,易於商業內容的保密 3 降低了sql呼叫方...