共計 1760 個字符,預計需要花費 5 分鐘才能閱讀完成。
這篇文章主要介紹“mysql 存儲過程怎么創建”的相關知識,丸趣 TV 小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“mysql 存儲過程怎么創建”文章能幫助大家解決問題。
在 mysql 中,可以利用“CREATE PROCEDURE”語句創建存儲過程,語法為“CREATE PROCEDURE 過程名 過程參數 過程體 過程參數 格式 [IN|OUT|INOUT] 參數名 類型”。
本教程操作環境:windows10 系統、mysql8.0.22 版本、Dell G3 電腦。
mysql 存儲過程語法是什么
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 存儲過程的創建
語法
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:
IN 參數的值必須在調用存儲過程時指定,在存儲過程中修改該參數的值不能被返回,為默認值
OUT: 該值可在存儲過程內部被改變,并可返回
INOUT: 調用時指定,并且可被改變和返回
過程體
過程體的開始與結束使用 BEGIN 與 END 進行標識。
關于“mysql 存儲過程怎么創建”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注丸趣 TV 行業資訊頻道,丸趣 TV 小編每天都會為大家更新不同的知識點。