MySQL儲存過程

2021-06-26 14:42:29 字數 3982 閱讀 7555

儲存過程(

stored procedure

)是一組為了完成特定功能的

sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數(如果該儲存過程帶有引數)來呼叫執行它。

mysql 儲存過程是從 mysql 5.0 開始增加的新功能。大大提高資料庫的處理速度,同時也可以提高資料庫程式設計的靈活性。

過程:封裝起來的若干條語句,呼叫時這些封裝體執行。把此過程儲存到資料庫中即儲存過程.

函式:是乙個有返回值的「過程」。

過程:沒有返回值的函式。

儲存過程的優點:

1、 儲存過程增強了

sql語言的功能和靈活性(可以sql程式設計,能使用變數,表示式、控制結構體) 2、

儲存過程能實現較快的執行速度。(

儲存過程要比批處理的執行速度快很多,

因為儲存過程是預編譯的。在首次執行乙個儲存過程時查詢,優化器對其進行分析優化,並且給出最終被儲存在系統表中的執行計畫。而批處理的

transaction-sql

語句在每次執行時都要進行編譯和優化,速度相對要慢一些。)

3、 儲存過程能過減少網路流量。

針對同乙個資料庫物件的操作(如查詢、修改),如果這一操作所涉及的

transaction-sql

語句被組織程儲存過程,那麼當在客戶計算機上呼叫該儲存過程時,網路中傳送的只是該呼叫語句,從而大大增加了網路流量並降低了網路負載。 4、

儲存過程可被作為一種安全機制來充分利用。

系統管理員通過執行某一儲存過程的許可權進行限制,能夠實現對相應的資料的訪問許可權的限制,避免了非授權使用者對資料的訪問,保證了資料的安全。

5、儲存過程允許標準元件是程式設計。儲存過程被建立後,可以在程式中被多次呼叫,而不必重新編寫該儲存過程的

sql語句。而且資料庫專業人員可以隨時對儲存過程進行修改,對應用程式源**毫無影響。

儲存過程的建立:

[sql]view plain

copy

delimiter $$  //定義分隔符  

create

procedure

p()   //p為過程名  

begin

--sql語句 //封裝語句體

end$$  

檢視已有的儲存過程:show procedure status \g;

呼叫儲存過程:call 儲存過程名稱();

刪除儲存過程:drop procedure 儲存過程名稱;

變數宣告:儲存過程中用declare宣告變數

格式:declare 變數名 變數型別 [default 預設值]

儲存過程中,變數可以在sql語句中合法的運算,如+ - * /

運算結果如何賦值

set 變數 := 表示式

儲存過程傳參:儲存過程的括號裡,可以宣告引數。 語法是 create procedure p([in/out/inout] 引數名  引數型別 ..)

in  

out  

例項一:建立 運算 賦值

[sql]view plain

copy

create

procedure

p1()  

begin

declare

age 

intdefault

18;  

declare

height 

intdefault

180;  

setage := age +20;  

select

concat(

'年齡是'

, age, 

'身高是'

例項二 :if/else 控制結構

[sql]view plain

copy

create

procedure

p2()  

begin

declare

age 

intdefault

18;  

declare

height 

intdefault

180;  

if age >= 18 then

select

"已成年"

;  else

select

"未成年"

例項三:while/do 控制結構

求1-100的和

例項四:case 控制結構

例項五:repeat迴圈

mysql儲存過程 MySQL儲存過程

在本節中,您將逐步學習如何在mysql中編寫和開發儲存過程。首先,我們向您介紹儲存過程的概念,並討論何時使用它。然後,展示如何使用過程 的基本元素,如建立儲存過程的語句,if else,case,loop,儲存過程的引數。下面每個教程都包含了易於理解的示例和詳細的說明。如果您瀏覽並學習所有教程,您可...

mysql 儲存過程 mysql 儲存過程

建立 為建立儲存過程的結束標誌,使用delimiter 可更改標誌 格式create procedure begin sqlend create procedure myprocedure in param integer begin select from tb role where tb rol...

mysql 儲存過程 MySQL儲存過程

目錄 儲存過程 簡介是一組為了完成特定功能的sql語句集合 比傳統sql速度更快 執行效率更高 儲存過程的優點 執行一次後,會將生成的二進位制 駐留緩衝區,提高執行效率 sql語句加上控制語句的集合,靈活性高 在伺服器端儲存,客戶端呼叫時,降低網路負載 可多次重複被呼叫,可隨時修改,不影響客戶端呼叫...