中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么寫數據庫的存儲過程

發布時間:2020-07-15 14:29:55 來源:億速云 閱讀:295 作者:Leah 欄目: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進行標識。

總結

  本次主要是掌握了對于存儲過程的使用,總的來說,存儲過程實際上類似于C++中的函數,而在C++中我們是需要在創建這一過程的文件中去調用這一函數,但是對于存儲過程來說,相當于是將這一操作過程存儲在數據庫中,可以使用call與對其進行調用,并輸入或者輸出一些參數和結果。

  印象最深的是類似“in n int”和“out sum int”這樣的對于輸入輸出的定義,通過查看相關博客,可以總結如下對于輸入輸出定義的使用規律:

  MySQL存儲過程的參數用在存儲過程的定義,共有三種參數類型

  IN,OUT,INOUT
  格式為:Create procedure|function([[IN |OUT |INOUT ] 參數名 數據類形...])

IN 輸入參數
  表示該參數的值必須在調用存儲過程時指定,在存儲過程中修改該參數的值不能被返回,為默認值

OUT 輸出參數
  該值可在存儲過程內部被改變,并可返回

INOUT 輸入輸出參數
  調用時指定,并且可被改變和返回

IN 和 OUT在實驗中已有體會,主要是對INOUT的理解,這里引用一個例子:

參數inout的使用實例(既能輸入一個值又能傳出來一個值)
語句功能:傳一個年齡,自動讓年齡增長10歲
create procedure p3(inout age int)
begin
set age:=age+10;
end
其中:調用的時候,inout型的參數值既是輸入類型又是輸出類型,給它一個值,值不是變量,因此我們需要先設置一個變量并初始化這個值,調用的時候直接傳這個變量即可。
set @currentAge=8$
call p3(@currentAge)$
select @currentAge$
創建并執行完存儲過程,運行結果如下:

怎么寫數據庫的存儲過程

看完上述內容,你們對怎么寫數據庫的存儲過程有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

涞源县| 长春市| 仁寿县| 石狮市| 岫岩| 江安县| 烟台市| 内江市| 弋阳县| 天长市| 定结县| 宁都县| 香河县| 余江县| 青神县| 天峻县| 建昌县| 梁山县| 遵义市| 台北市| 怀柔区| 托克托县| 饶平县| 大姚县| 扶绥县| 班玛县| 象州县| 内江市| 永春县| 辽阳市| 玛纳斯县| 资阳市| 郎溪县| 额济纳旗| 谢通门县| 古丈县| 永嘉县| 福贡县| 岳西县| 碌曲县| 静安区|