您好,登錄后才能下訂單哦!
小編給大家分享一下數(shù)據(jù)庫存儲過程如何寫,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
存儲過程簡介
SQL語句需要先編譯然后執(zhí)行,而存儲過程(Stored Procedure)是一組為了完成特定功能的SQL語句集,經(jīng)編譯后存儲在數(shù)據(jù)庫中,用戶通過指定存儲過程的名字并給定參數(shù)(如果該存儲過程帶有參數(shù))來調(diào)用執(zhí)行它。存儲過程是可編程的函數(shù),在數(shù)據(jù)庫中創(chuàng)建并保存,可以由SQL語句和控制結(jié)構(gòu)組成。當想要在不同的應用程序或平臺上執(zhí)行相同的函數(shù),或者封裝特定功能時,存儲過程是非常有用的。數(shù)據(jù)庫中的存儲過程可以看做是對編程中面向?qū)ο蠓椒ǖ哪M,它允許控制數(shù)據(jù)的訪問方式。
存儲過程的優(yōu)點:
(1).增強SQL語言的功能和靈活性:存儲過程可以用控制語句編寫,有很強的靈活性,可以完成復雜的判斷和較復雜的運算。
(2).標準組件式編程:存儲過程被創(chuàng)建后,可以在程序中被多次調(diào)用,而不必重新編寫該存儲過程的SQL語句。而且數(shù)據(jù)庫專業(yè)人員可以隨時對存儲過程進行修改,對應用程序源代碼毫無影響。
(3).較快的執(zhí)行速度:如果某一操作包含大量的Transaction-SQL代碼或分別被多次執(zhí)行,那么存儲過程要比批處理的執(zhí)行速度快很多。因為存儲過程是預編譯的。在首次運行一個存儲過程時查詢,優(yōu)化器對其進行分析優(yōu)化,并且給出最終被存儲在系統(tǒng)表中的執(zhí)行計劃。而批處理的Transaction-SQL語句在每次運行時都要進行編譯和優(yōu)化,速度相對要慢一些。
(4).減少網(wǎng)絡流量:針對同一個數(shù)據(jù)庫對象的操作(如查詢、修改),如果這一操作所涉及的Transaction-SQL語句被組織進存儲過程,那么當在客戶計算機上調(diào)用該存儲過程時,網(wǎng)絡中傳送的只是該調(diào)用語句,從而大大減少網(wǎng)絡流量并降低了網(wǎng)絡負載。
(5).作為一種安全機制來充分利用:通過對執(zhí)行某一存儲過程的權(quán)限進行限制,能夠?qū)崿F(xiàn)對相應的數(shù)據(jù)的訪問權(quán)限的限制,避免了非授權(quán)用戶對數(shù)據(jù)的訪問,保證了數(shù)據(jù)的安全。
MySQL的存儲過程
存儲過程是數(shù)據(jù)庫的一個重要的功能,MySQL 5.0以前并不支持存儲過程,這使得MySQL在應用上大打折扣。好在MySQL 5.0開始支持存儲過程,這樣即可以大大提高數(shù)據(jù)庫的處理速度,同時也可以提高數(shù)據(jù)庫編程的靈活性。
MySQL存儲過程的創(chuàng)建
語法
CREATE PROCEDURE 過程名([[IN|OUT|INOUT] 參數(shù)名 數(shù)據(jù)類型[,[IN|OUT|INOUT] 參數(shù)名 數(shù)據(jù)類型…]]) [特性 ...] 過程體 DELIMITER // CREATE PROCEDURE myproc(OUT s int) BEGIN SELECT COUNT(*) INTO s FROM students; END // DELIMITER ;
分隔符
MySQL默認以";"為分隔符,如果沒有聲明分割符,則編譯器會把存儲過程當成SQL語句進行處理,因此編譯過程會報錯,所以要事先用“DELIMITER //”聲明當前段分隔符,讓編譯器把兩個"//"之間的內(nèi)容當做存儲過程的代碼,不會執(zhí)行這些代碼;“DELIMITER ;”的意為把分隔符還原。
參數(shù)
存儲過程根據(jù)需要可能會有輸入、輸出、輸入輸出參數(shù),如果有多個參數(shù)用","分割開。MySQL存儲過程的參數(shù)用在存儲過程的定義,共有三種參數(shù)類型,IN,OUT,INOUT:
IN參數(shù)的值必須在調(diào)用存儲過程時指定,在存儲過程中修改該參數(shù)的值不能被返回,為默認值OUT:該值可在存儲過程內(nèi)部被改變,并可返回INOUT:調(diào)用時指定,并且可被改變和返回
過程體
過程體的開始與結(jié)束使用BEGIN與END進行標識。
總結(jié)
本次主要是掌握了對于存儲過程的使用,總的來說,存儲過程實際上類似于C++中的函數(shù),而在C++中我們是需要在創(chuàng)建這一過程的文件中去調(diào)用這一函數(shù),但是對于存儲過程來說,相當于是將這一操作過程存儲在數(shù)據(jù)庫中,可以使用call與對其進行調(diào)用,并輸入或者輸出一些參數(shù)和結(jié)果。
印象最深的是類似“in n int”和“out sum int”這樣的對于輸入輸出的定義,通過查看相關(guān)博客,可以總結(jié)如下對于輸入輸出定義的使用規(guī)律:
MySQL存儲過程的參數(shù)用在存儲過程的定義,共有三種參數(shù)類型
IN,OUT,INOUT
格式為:Create procedure|function([[IN |OUT |INOUT ] 參數(shù)名 數(shù)據(jù)類形...])
IN 輸入?yún)?shù)
表示該參數(shù)的值必須在調(diào)用存儲過程時指定,在存儲過程中修改該參數(shù)的值不能被返回,為默認值
OUT 輸出參數(shù)
該值可在存儲過程內(nèi)部被改變,并可返回
INOUT 輸入輸出參數(shù)
調(diào)用時指定,并且可被改變和返回
IN 和 OUT在實驗中已有體會,主要是對INOUT的理解,這里引用一個例子:
參數(shù)inout的使用實例(既能輸入一個值又能傳出來一個值)
語句功能:傳一個年齡,自動讓年齡增長10歲
create procedure p3(inout age int)
begin
set age:=age+10;
end
其中:調(diào)用的時候,inout型的參數(shù)值既是輸入類型又是輸出類型,給它一個值,值不是變量,因此我們需要先設置一個變量并初始化這個值,調(diào)用的時候直接傳這個變量即可。
set @currentAge=8$
call p3(@currentAge)$
select @currentAge$
創(chuàng)建并執(zhí)行完存儲過程,運行結(jié)果如下:
以上是數(shù)據(jù)庫存儲過程如何寫的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。