在mysql中,存儲過程是一組為了完成特定功能的SQL語句集合。使用存儲過程的目的是將常用或復雜的工作預先用SQL語句寫好并用一個指定名稱存儲起來,這個過程經編譯和優化后存儲在數據庫服務器中,因此稱為存儲過程。
本教程操作環境:windows7系統、mysql8版本、Dell G3電腦。
存儲過程(Stored Procedure)是一種在數據庫中存儲復雜程序,以便外部程序調用的一種數據庫對象。
存儲過程是一組為了完成特定功能的 SQL 語句集合。使用存儲過程的目的是將常用或復雜的工作預先用 SQL 語句寫好并用一個指定名稱存儲起來,這個過程經編譯和優化后存儲在數據庫服務器中,因此稱為存儲過程。當以后需要數據庫提供與已定義好的存儲過程的功能相同的服務時,只需調用“CALL存儲過程名字”即可自動完成。
常用操作數據庫的 SQL 語句在執行的時候需要先編譯,然后執行。存儲過程則采用另一種方式來執行 SQL 語句。
一個存儲過程是一個可編程的函數,它在數據庫中創建并保存,一般由 SQL 語句和一些特殊的控制結構組成。當希望在不同的應用程序或平臺上執行相同的特定功能時,存儲過程尤為合適。
MySQL 5.0 版本以前并不支持存儲過程,這使 MySQL 在應用上大打折扣。MySQL 從 5.0 版本開始支持存儲過程,既提高了數據庫的處理速度,同時也提高了數據庫編程的靈活性
存儲過程是數據庫中的一個重要功能,存儲過程可以用來轉換數據、數據遷移、制作報表,它類似于編程語言,一次執行成功,就可以隨時被調用,完成指定的功能操作。
使用存儲過程不僅可以提高數據庫的訪問效率,同時也可以提高數據庫使用的安全性。
對于調用者來說,存儲過程封裝了 SQL 語句,調用者無需考慮邏輯功能的具體實現過程。只是簡單調用即可,它可以被 Java 和 C# 等編程語言調用。
創建存儲過程
可以使用 CREATE PROCEDURE 語句創建存儲過程,語法格式如下:
CREATE?PROCEDURE??(?[過程參數[,…]?]?)?
[過程參數[,…] ] 格式
[?IN?|?OUT?|?INOUT?]??
語法說明如下:
1) 過程名
存儲過程的名稱,默認在當前數據庫中創建。若需要在特定數據庫中創建存儲過程,則要在名稱前面加上數據庫的名稱,即 db_name.sp_name。
需要注意的是,名稱應當盡量避免選取與 MySQL 內置函數相同的名稱,否則會發生錯誤。
2) 過程參數
存儲過程的參數列表。其中,為參數名,為參數的類型(可以是任何有效的 MySQL 數據類型)。當有多個參數時,參數列表中彼此間用逗號分隔。存儲過程可以沒有參數(此時存儲過程的名稱后仍需加上一對括號),也可以有 1 個或多個參數。
MySQL 存儲過程支持三種類型的參數,即輸入參數、輸出參數和輸入/輸出參數,分別用 IN、OUT 和 INOUT 三個關鍵字標識。其中,輸入參數可以傳遞給一個存儲過程,輸出參數用于存儲過程需要返回一個操作結果的情形,而輸入/輸出參數既可以充當輸入參數也可以充當輸出參數。
需要注意的是,參數的取名不要與數據表的列名相同,否則盡管不會返回出錯信息,但是存儲過程的 SQL 語句會將參數名看作列名,從而引發不可預知的結果。
3) 過程體
存儲過程的主體部分,也稱為存儲過程體,包含在過程調用的時候必須執行的 SQL 語句。這個部分以關鍵字 BEGIN 開始,以關鍵字 END 結束。若存儲過程體中只有一條 SQL 語句,則可以省略 BEGIN-END 標志。
示例:
創建名稱為 ShowStuScore 的存儲過程,存儲過程的作用是從學生成績信息表中查詢學生的成績信息,輸入的 SQL 語句和執行過程如下所示。
mysql>?DELIMITER?// mysql>?CREATE?PROCEDURE?ShowStuScore() ????->?BEGIN ????->?SELECT?*?FROM?tb_students_score; ????->?END?// Query?OK,?0?rows?affected?(0.09?sec)
結果顯示 ShowStuScore 存儲過程已經創建成功。
刪除存儲過程
存儲過程被創建后,就會一直保存在數據庫服務器上,直至被刪除。當 MySQL 數據庫中存在廢棄的存儲過程時,我們需要將它從數據庫中刪除。
MySQL 中使用 DROP PROCEDURE 語句來刪除數據庫中已經存在的存儲過程。語法格式如下:
DROP?PROCEDURE?[?IF?EXISTS?]?
語法說明如下:
-
過程名:指定要刪除的存儲過程的名稱。
-
IF EXISTS:指定這個關鍵字,用于防止因刪除不存在的存儲過程而引發的錯誤。
注意:存儲過程名稱后面沒有參數列表,也沒有括號,在刪除之前,必須確認該存儲過程沒有任何依賴關系,否則會導致其他與之關聯的存儲過程無法運行。
實例
下面刪除存儲過程 ShowStuScore,SQL 語句和運行結果如下:
mysql>?DROP?PROCEDURE?ShowStuScore; Query?OK,?0?rows?affected?(0.08?sec)
刪除后,可以通過查詢 information_schema 數據庫下的 routines 表來確認上面的刪除是否成功。SQL 語句和運行結果如下:
mysql>?SELECT?*?FROM?information_schema.routines?WHERE?routine_name='ShowStuScore'; Empty?set?(0.03?sec)
結果顯示,沒有查詢出任何記錄,說明存儲過程 ShowStuScore 已經被刪除了。
(推薦教程:mysql視頻教程)