MySQL数据库:存储过程Procedure
?
一、存儲過程:
SQL語句需要先編譯然后執行,而存儲過程是一組為了完成特定功能的SQL語句集,經編譯后存儲在數據庫中,用戶通過指定存儲過程的名字并給定參數(如果該存儲過程帶有參數)來調用它。
存儲過程是可編程的函數,在數據庫中創建并保存,可以由SQL語句和控制結構組成。當想要在不同的應用程序或平臺上執行相同的函數,或者封裝特定功能時,存儲過程是非常有用的。數據庫中的存儲過程可以看做是對編程中面向對象方法的模擬,它允許控制數據的訪問方式。
1、為什么需要存儲過程:
有人說,不需要把復雜過程封裝成MySQL存儲過程,用程序(C++/JAVA)也能實現復雜邏輯。如果用程序調用API執行,其實效率相對較慢,原因在于你的應用程序要通過引擎把MySQL語句交付給MySQL引擎來執行,那就不如直接讓MySQL負責它最精通最能夠完成的工作,所以可以在開發中可以將某些常用的操作封裝成存儲過程。
2、存儲過程和自定義函數的區別:
(1)存儲過程實現的功能要復雜一些,而函數的針對性更強;
(2)存儲過程可以返回多個值,函數只能有一個返回值;
(3)存儲過程一般獨立的來執行;而函數可以作為其他SQL語句的組成部分來實現。
?
二、存儲過程的優點:
(1)增強SQL語言的功能和靈活性:存儲過程可以用控制語句編寫,有很強的靈活性,可以完成復雜的判斷和較復雜的運算。
(2)標準組件式編程:存儲過程被創建后,可以在程序中被多次調用,而不必重新編寫該存儲過程的SQL語句。而且數據庫專業人員可以隨時對存儲過程進行修改,對應用程序源代碼毫無影響。
(3)較快的執行速度:如果某一操作包含大量的Transaction-SQL代碼或分別被多次執行,那么存儲過程要比批處理的執行速度快很多。因為存儲過程是預編譯的。在首次運行一個存儲過程時查詢,優化器對其進行分析優化,并且給出最終被存儲在系統表中的執行計劃。而批處理的Transaction-SQL語句在每次運行時都要進行編譯和優化,速度相對要慢一些。
(4)減少網絡流量:針對同一個數據庫對象的操作(如查詢、修改),如果這一操作所涉及的Transaction-SQL語句被組織進存儲過程,那么當在客戶計算機上調用該存儲過程時,網絡中傳送的只是該調用語句,從而大大減少網絡流量并降低了網絡負載。
(5)作為一種安全機制來充分利用:通過對執行某一存儲過程的權限進行限制,能夠實現對相應的數據的訪問權限的限制,避免了非授權用戶對數據的訪問,保證了數據的安全。
?
三、MySQL存儲過程的相關操作:
1、存儲過程的創建:
語法:
CREATE PROCEDURE??過程名([[IN|OUT|INOUT] 參數名 數據類型[,[IN|OUT|INOUT] 參數名 數據類型…]]) [特性 ...] 過程體
DELIMITER //
??CREATE PROCEDURE myproc(OUT s int)
????BEGIN
??????SELECT COUNT(*) INTO s FROM students;
????END
????//
DELIMITER ;
(1)分隔符:MySQL默認以";"為分隔符,如果沒有聲明分割符,則編譯器會把存儲過程當成SQL語句進行處理,因此編譯過程會報錯,所以要事先用“DELIMITER //”聲明當前段分隔符,讓編譯器把兩個"//"之間的內容當做存儲過程的代碼,不會執行這些代碼;“DELIMITER ;”的意為把分隔符還原。
(2)參數:存儲過程根據需要可能會有輸入、輸出、輸入輸出參數,如果有多個參數用","分割開。MySQL存儲過程的參數用在存儲過程的定義,共有三種參數類型,IN,OUT,INOUT:
IN:參數的值必須在調用存儲過程時指定,在存儲過程中修改該參數的值不能被返回,為默認值
OUT:該值可在存儲過程內部被改變,并可返回
INOUT:調用時指定,并且可被改變和返回
(3)過程體:過程體的開始與結束使用BEGIN與END進行標識。
2、MySQL存儲過程的調用:
用call和你過程名以及一個括號,括號里面根據需要,加入參數,參數包括輸入參數、輸出參數、輸入輸出參數。
3、MySQL存儲過程的查詢信息:
?#查詢存儲過程:
SELECT name FROM mysql.proc WHERE db='數據庫名';
SELECT routine_name FROM information_schema.routines WHERE routine_schema='數據庫名';
SHOW PROCEDURE STATUS WHERE db='數據庫名';
#查看存儲過程的定義:
SHOW CREATE PROCEDURE 數據庫.存儲過程名;
#查看狀態:
SHOW [PROCEDURE|FUNCTION] STATUS [LIKE 'pattern']
4、MySQL存儲過程的修改:
使用ALTER PROCEDURE 更改用CREATE PROCEDURE 建立的預先指定的存儲過程,其不會影響相關存儲過程或存儲功能。
ALTER {PROCEDURE | FUNCTION} sp_name [characteristic ...]
characteristic:
{ CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
| SQL SECURITY { DEFINER | INVOKER }
| COMMENT 'string'
(1)sp_name參數表示存儲過程或函數的名稱;
(2)characteristic參數指定存儲函數的特性。
(3)CONTAINS SQL表示子程序包含SQL語句,但不包含讀或寫數據的語句;
(4)NO SQL表示子程序中不包含SQL語句;
(5)READS SQL DATA表示子程序中包含讀數據的語句;
(6)MODIFIES SQL DATA表示子程序中包含寫數據的語句。
(7)SQL SECURITY { DEFINER | INVOKER }指明誰有權限來執行,DEFINER表示只有定義者自己才能夠執行;INVOKER表示調用者可以執行。
(8)COMMENT 'string'是注釋信息。
實例:
#將讀寫權限改為MODIFIES SQL DATA,并指明調用者可以執行。
ALTER ?PROCEDURE ?num_from_employee
? MODIFIES SQL DATA
??SQL SECURITY INVOKER ;
#將讀寫權限改為READS SQL DATA,并加上注釋信息'FIND NAME'。
ALTER ?PROCEDURE ?name_from_employee
??READS SQL DATA
??COMMENT 'FIND NAME' ;
5、MySQL存儲過程的刪除:
#從MySQL的表格中刪除一個或多個存儲過程。
DROP PROCEDURE [過程1[,過程2…]]
?
?
其他更多的有關存儲引擎的操作可以參考這篇文章:
https://www.cnblogs.com/mark-chan/p/5384139.html
總結
以上是生活随笔為你收集整理的MySQL数据库:存储过程Procedure的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySQL数据库:锁机制
- 下一篇: MySQL数据库:视图View