MySQL儲存過程詳解 mysql 儲存過程

2021-09-24 10:21:41 字數 3755 閱讀 3707

儲存過程簡介

我們常用的運算元據庫語言sql語句在執行的時候需要要先編譯,然後執行,而儲存過程(stored procedure)是一組為了完成特定功能的sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數(如果該儲存過程帶有引數)來呼叫執行它。

乙個儲存過程是乙個可程式設計的函式,它在資料庫中建立並儲存。它可以有sql語句和一些特殊的控制結構組成。當希望在不同的應用程式或平台上執行相同的函式,或者封裝特定功能時,儲存過程是非常有用的。資料庫中的儲存過程可以看做是對程式設計中物件導向方法的模擬。它允許控制資料的訪問方式。

儲存過程通常有以下優點:

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

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

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

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

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

關於mysql的儲存過程

儲存過程是資料庫儲存的乙個重要的功能,但是mysql在5.0以前並不支援儲存過程,這使得mysql在應用上大打折扣。好在mysql 5.0終於開始已經支援儲存過程,這樣即可以大大提高資料庫的處理速度,同時也可以提高資料庫程式設計的靈活性。

mysql儲存過程的建立

(1). 格式

mysql儲存過程建立的格式:create procedure 過程名 ([過程引數[,...]])

[特性 ...] 過程體

這裡先舉個例子:

mysql> delimiter //  

mysql> create procedure proc1(out s int)  

-> begin 

-> select count(*) into s from user;  

-> end 

mysql> delimiter ; 

ps:(1)這裡需要注意的是delimiter //和delimiter ;兩句,delimiter是分割符的意思,因為mysql預設以";"為分隔符,如果我們沒有宣告分割符,那麼編譯器會把儲存過程當成sql語句進行處理,則儲存過程的編譯過程會報錯,所以要事先用delimiter關鍵字申明當前段分隔符,這樣mysql才會將";"當做儲存過程中的**,不會執行這些**,用完了之後要把分隔符還原。

(2)儲存過程根據需要可能會有輸入、輸出、輸入輸出引數,這裡有乙個輸出引數s,型別是int型,如果有多個引數用","分割開。

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

這樣,我們的乙個mysql儲存過程就完成了,是不是很容易呢?看不懂也沒關係,接下來,我們詳細的講解。

(2). 宣告分割符

其實,關於宣告分割符,上面的註解已經寫得很清楚,不需要多說,只是稍微要注意一點的是:如果是用mysql的administrator管理工具時,可以直接建立,不再需要宣告。

(3). 引數

mysql儲存過程的引數用在儲存過程的定義,共有三種引數型別,in,out,inout,形式如:

create procedure([[in |out |inout ] 引數名 資料類形...])

in 輸入引數:表示該引數的值必須在呼叫儲存過程時指定,在儲存過程中修改該引數的值不能被返回,為預設值

out 輸出引數:該值可在儲存過程內部被改變,並可返回

inout 輸入輸出引數:呼叫時指定,並且可被改變和返回

in引數例子

建立:mysql > delimiter //  

mysql > create procedure demo_in_parameter(in p_in int)  

-> begin   

-> select p_in;   

-> set p_in=2;   

-> select p_in;   

-> end;   

mysql > delimiter ; 

執行: mysql > set @p_in=1;  

mysql > call demo_in_parameter(@p_in);  

| p_in |  

|   1  |   

| p_in |  

|   2  |   

mysql> select @p_in;  

| @p_in |  

|  1    |  

以上可以看出,p_in雖然在儲存過程中被修改,但並不影響@p_in的值

out引數例子

建立: mysql > delimiter //  

mysql > create procedure demo_out_parameter(out p_out int)  

-> begin 

-> select p_out;  

-> set p_out=2;  

-> select p_out;  

-> end;  

mysql > delimiter ; 

執行: mysql > set @p_out=1;  

mysql > call sp_demo_out_parameter(@p_out);  

| p_out |   

| null  |   

| p_out |  

|   2   |   

mysql> select @p_out;  

| p_out |  

|   2   |  

inout引數例子

建立: mysql > delimiter //   

mysql > create procedure demo_inout_parameter(inout p_inout int)   

-> begin 

-> select p_inout;  

-> set p_inout=2;  

-> select p_inout;   

-> end;  

mysql > delimiter ; 

執行: mysql > set @p_inout=1;  

mysql > call demo_inout_parameter(@p_inout) ;  

| p_inout |  

|    1    |  

| p_inout |   

|    2    |  

mysql > select @p_inout;  

| @p_inout |   

|    2     |  

Mysq 儲存過程

drop procedure if exists xl 建立儲存過程 delimiter 轉譯字元 使用 代替 create procedure xl begin select from fd car report end delimiter 轉譯字元 使用 代替 call xl 呼叫儲存過程 de...

MySql儲存過程詳解

sql語句需要先編譯然後執行,而儲存過程是一組為了完成特定功能的sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數 如果該儲存過程帶有引數 來呼叫它。儲存過程是可程式設計的函式,在資料庫中建立並儲存,可以由sql語句和控制結構組成。當想要在不同的應用程式或平台上執行相同的函...

MySQL儲存過程詳解

我們常用的運算元據庫語言sql語句在執行的時候需要要先編譯,然後執行,而儲存過程 stored procedure 是一組為了完成特定功能的sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數 如果該儲存過程帶有引數 來呼叫執行它。乙個儲存過程是乙個可程式設計的函式,它在資料...