mysql儲存過程

2023-01-21 13:11:52 字數 1595 閱讀 8250

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

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

儲存過程的優點:

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

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

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

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

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

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

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:

mysql儲存過程 Mysql儲存過程的詳細講解

第一 怎麼是mysql儲存過程?儲存過程是一組為了完成特定功能的 sql 語句集合。mysql 5.0 終於開始已經支援儲存過程,它是資料庫中最重要的功能,1.使用儲存過程的目的 將常用或複雜的工作預先用 sql 語句寫好並用一個指定名稱儲存起來,這個過程經編譯和優化後儲存在資料庫伺服器中,因此稱為...

mysql儲存過程 MySQL儲存過程例項

mysql在5.1之後增加了儲存過程的功能,儲存過程執行在mysql內部,語句都已經編譯好了,速度比sql更快.儲存過程與mysql相當於shell和linux系統。如果你是程式設計師的話,那我告訴你儲存過程實際上是一個方法,你只要呼叫這個方法,並且輸入它設定好的引數就可以獲取或者執行你想要的操作了...

mysql儲存過程 mysql儲存過程的寫法

可以使用 create procedure 語句建立儲存過程。資料庫儲存過程語法格式如下 create procedure 過程名 in out inout 引數名 資料型別 in out inout 引數名 資料型別 特性 過程體 delimiter create procedure myproc...