成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一看就懂的MySQL存儲過程詳解

存儲 存儲軟件 MySQL
我們常用的操作數據庫語言SQL語句在執行的時候需要要先編譯,然后執行,而存儲過程(Stored Procedure)是一組為了完成特定功能的SQL語句集,經編譯后存儲在數據庫中,用戶通過指定存儲過程的名字并給定參數(如果該存儲過程帶有參數)來調用執行它。

[[244976]]

圖片來自包圖網

1. 存儲過程簡介

我們常用的操作數據庫語言SQL語句在執行的時候需要要先編譯,然后執行,而存儲過程(Stored Procedure)是一組為了完成特定功能的SQL語句集,經編譯后存儲在數據庫中,用戶通過指定存儲過程的名字并給定參數(如果該存儲過程帶有參數)來調用執行它。

一個存儲過程是一個可編程的函數,它在數據庫中創建并保存。它可以有SQL語句和一些特殊的控制結構組成。當希望在不同的應用程序或平臺上執行相同的函數,或者封裝特定功能時,存儲過程是非常有用的。數據庫中的存儲過程可以看做是對編程中面向對象方法的模擬。它允許控制數據的訪問方式。

存儲過程通常有以下優點:

(1).存儲過程增強了SQL語言的功能和靈活性。存儲過程可以用流控制語句編寫,有很強的靈活性,可以完成復雜的判斷和較復雜的運算。

(2).存儲過程允許標準組件是編程。存儲過程被創建后,可以在程序中被多次調用,而不必重新編寫該存儲過程的SQL語句。而且數據庫專業人員可以隨時對存儲過程進行修改,對應用程序源代碼毫無影響。

(3).存儲過程能實現較快的執行速度。如果某一操作包含大量的Transaction-SQL代碼或分別被多次執行,那么存儲過程要比批處理的執行速度快很多。因為存儲過程是預編譯的。在首次運行一個存儲過程時查詢,優化器對其進行分析優化,并且給出最終被存儲在系統表中的執行計劃。而批處理的Transaction-SQL語句在每次運行時都要進行編譯和優化,速度相對要慢一些。

(4).存儲過程能過減少網絡流量。針對同一個數據庫對象的操作(如查詢、修改),如果這一操作所涉及的Transaction-SQL語句被組織程存儲過程,那么當在客戶計算機上調用該存儲過程時,網絡中傳送的只是該調用語句,從而大大增加了網絡流量并降低了網絡負載。

(5).存儲過程可被作為一種安全機制來充分利用。系統管理員通過執行某一存儲過程的權限進行限制,能夠實現對相應的數據的訪問權限的限制,避免了非授權用戶對數據的訪問,保證了數據的安全。

2. 關于MySQL的存儲過程

存儲過程是數據庫存儲的一個重要的功能,但是MySQL在5.0以前并不支持存儲過程,這使得MySQL在應用上大打折扣。好在MySQL 5.0終于開始已經支持存儲過程,這樣即可以大大提高數據庫的處理速度,同時也可以提高數據庫編程的靈活性。

3. MySQL存儲過程的創建

(1). 格式

MySQL存儲過程創建的格式:CREATE PROCEDURE 過程名 ([過程參數[,...]])

[特性 ...] 過程體

這里先舉個例子

  1. mysql> DELIMITER // 
  2.  
  3. mysql> CREATE PROCEDURE proc1(OUT s int
  4.  
  5. -> BEGIN 
  6.  
  7. -> SELECT COUNT(*) INTO s FROM user
  8.  
  9. -> END 
  10.  
  11. -> // 
  12.  
  13. mysql> DELIMITER ; 
  1. 這里需要注意的是DELIMITER //和DELIMITER ;兩句,DELIMITER是分割符的意思,因為MySQL默認以";"為分隔符,如果我們沒有聲明分割符,那么編譯器會把存儲過程當成SQL語句進行處理,則存儲過程的編譯過程會報錯,所以要事先用DELIMITER關鍵字申明當前段分隔符,這樣MySQL才會將";"當做存儲過程中的代碼,不會執行這些代碼,用完了之后要把分隔符還原。
  2. 存儲過程根據需要可能會有輸入、輸出、輸入輸出參數,這里有一個輸出參數s,類型是int型,如果有多個參數用","分割開。
  3. 過程體的開始與結束使用BEGIN與END進行標識。

這樣,我們的一個MySQL存儲過程就完成了,是不是很容易呢?看不懂也沒關系,接下來,我們詳細的講解。

(2). 聲明分割符

其實,關于聲明分割符,上面的注解已經寫得很清楚,不需要多說,只是稍微要注意一點的是:如果是用MySQL的Administrator管理工具時,可以直接創建,不再需要聲明。

(3). 參數

MySQL存儲過程的參數用在存儲過程的定義,共有三種參數類型,IN,OUT,INOUT,形式如:

CREATE PROCEDURE([[IN |OUT |INOUT ] 參數名 數據類形...])

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

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

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

Ⅰ. IN參數例子

創建:

  1. mysql > DELIMITER // 
  2. mysql > CREATE PROCEDURE demo_in_parameter(IN p_in int
  3. -> BEGIN 
  4. -> SELECT p_in; 
  5. -> SET p_in=2; 
  6. -> SELECT p_in; 
  7. -> END
  8. -> // 
  9. mysql > DELIMITER ; 

執行結果:

  1. mysql > SET @p_in=1; 
  2. mysql > CALL demo_in_parameter(@p_in); 
  3. +------+ 
  4. | p_in | 
  5. +------+ 
  6. | 1 | 
  7. +------+ 
  8. +------+ 
  9. | p_in | 
  10. +------+ 
  11. | 2 | 
  12. +------+ 
  13. mysql> SELECT @p_in; 
  14. +-------+ 
  15. | @p_in | 
  16. +-------+ 
  17. | 1 | 
  18. +-------+ 

以上可以看出,p_in雖然在存儲過程中被修改,但并不影響@p_id的值

Ⅱ.OUT參數例子

創建:

  1. mysql > DELIMITER // 
  2. mysql > CREATE PROCEDURE demo_out_parameter(OUT p_out int
  3. -> BEGIN 
  4. -> SELECT p_out; 
  5. -> SET p_out=2; 
  6. -> SELECT p_out; 
  7. -> END
  8. -> // 
  9. mysql > DELIMITER ; 

執行結果:

  1. mysql > SET @p_out=1; 
  2. mysql > CALL sp_demo_out_parameter(@p_out); 
  3. +-------+ 
  4. | p_out | 
  5. +-------+ 
  6. NULL | 
  7. +-------+ 
  8. +-------+ 
  9. | p_out | 
  10. +-------+ 
  11. | 2 | 
  12. +-------+ 
  13. mysql> SELECT @p_out; 
  14. +-------+ 
  15. | p_out | 
  16. +-------+ 
  17. | 2 | 
  18. +-------+ 

Ⅲ. INOUT參數例子

創建:

  1. mysql > DELIMITER // 
  2. mysql > CREATE PROCEDURE demo_inout_parameter(INOUT p_inout int
  3. -> BEGIN 
  4. -> SELECT p_inout; 
  5. -> SET p_inout=2; 
  6. -> SELECT p_inout; 
  7. -> END
  8. -> // 
  9. mysql > DELIMITER ; 

執行結果:

  1. mysql > SET @p_inout=1; 
  2. mysql > CALL demo_inout_parameter(@p_inout) ; 
  3. +---------+ 
  4. | p_inout | 
  5. +---------+ 
  6. | 1 | 
  7. +---------+ 
  8. +---------+ 
  9. | p_inout | 
  10. +---------+ 
  11. | 2 | 
  12. +---------+ 
  13. mysql > SELECT @p_inout; 
  14. +----------+ 
  15. | @p_inout | 
  16. +----------+ 
  17. | 2 | 
  18. +----------+ 

(4). 變量

Ⅰ. 變量定義

DECLARE variable_name [,variable_name...] datatype [DEFAULT value];

其中,datatype為MySQL的數據類型,如:int, float, date, varchar(length)

例如:

  1. DECLARE l_int int unsigned default 4000000;
  2. DECLARE l_numeric number(8,2) DEFAULT 9.95;
  3. DECLARE l_date date DEFAULT '1999-12-31';
  4. DECLARE l_datetime datetime DEFAULT '1999-12-31 23:59:59';
  5. DECLARE l_varchar varchar(255) DEFAULT 'This will not be padded';

Ⅱ. 變量賦值 SET 變量名 = 表達式值 [,variable_name = expression ...]

Ⅲ. 用戶變量

ⅰ. 在MySQL客戶端使用用戶變量

  1. mysql > SELECT 'Hello World' into @x; 
  2. mysql > SELECT @x; 
  3. +-------------+ 
  4. | @x | 
  5. +-------------+ 
  6. | Hello World | 
  7. +-------------+ 
  8. mysql > SET @y='Goodbye Cruel World'
  9. mysql > SELECT @y; 
  10. +---------------------+ 
  11. | @y | 
  12. +---------------------+ 
  13. | Goodbye Cruel World | 
  14. +---------------------+ 
  15. mysql > SET @z=1+2+3; 
  16. mysql > SELECT @z; 
  17. +------+ 
  18. | @z | 
  19. +------+ 
  20. | 6 | 
  21. +------+ 

ⅱ. 在存儲過程中使用用戶變量

  1. mysql > CREATE PROCEDURE GreetWorld( ) SELECT CONCAT(@greeting,' World'); 
  2. mysql > SET @greeting='Hello'
  3. mysql > CALL GreetWorld( ); 
  4. +----------------------------+ 
  5. | CONCAT(@greeting,' World') | 
  6. +----------------------------+ 
  7. | Hello World | 
  8. +----------------------------+ 

ⅲ. 在存儲過程間傳遞全局范圍的用戶變量

  1. mysql> CREATE PROCEDURE p1() SET @last_procedure='p1'
  2. mysql> CREATE PROCEDURE p2() SELECT CONCAT('Last procedure was ',@last_proc); 
  3. mysql> CALL p1( ); 
  4. mysql> CALL p2( ); 
  5. +-----------------------------------------------+ 
  6. | CONCAT('Last procedure was ',@last_proc | 
  7. +-----------------------------------------------+ 
  8. Last procedure was p1 | 
  9. +-----------------------------------------------+ 
責任編輯:武曉燕 來源: 今日頭條
相關推薦

2020-09-21 08:33:12

線程池調度Thread Pool

2023-05-12 09:08:48

TypeScript工具類型

2021-07-15 09:55:47

systemdLinux文件

2020-04-15 08:33:43

Netty網絡通信

2020-03-27 09:06:54

選擇排序算法冒泡排序

2021-05-14 07:11:49

方法調用類加載

2022-05-29 22:55:00

適配器設計模式

2021-12-30 09:10:28

游戲開發開發技術熱點

2022-08-15 19:49:57

Consul架構注冊中心

2019-08-14 10:20:32

算法數組鏈表

2019-01-15 09:55:24

RAID磁盤陣列數據存儲

2020-05-09 14:40:29

UI設計開發

2015-07-21 13:07:14

Reactjs教程

2025-03-04 02:00:00

Python編寫自動化

2024-12-12 08:22:03

負載均衡算法無狀態

2024-11-20 16:02:47

.NET 9LINQ開發

2021-05-13 07:30:27

Kafka消息流系統

2021-01-07 10:30:23

設計模式

2019-08-22 09:22:44

數據結構二叉搜索樹

2020-11-26 10:33:44

MySQL存儲函數
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日本一卡精品视频免费 | 精品国产黄色片 | 宅女噜噜66国产精品观看免费 | 日日av| 新91视频网 | 欧美一区2区三区4区公司 | 神马久久久久久久久久 | 91精品国产综合久久精品 | 久久蜜桃av一区二区天堂 | 9porny九色视频自拍 | 宅男噜噜噜66一区二区 | 黄色欧美在线 | 中文字幕 在线观看 | 国产福利资源 | 日本在线观看视频 | 亚洲不卡在线视频 | 91电影在线 | 久久久精品网 | 免费国产一区 | 亚洲国产精品区 | 黄色一级大片视频 | 7777久久 | 久久久久国产精品一区二区 | 国产99热精品 | 久久久久亚洲精品 | 亚洲国产精品久久久 | 国产sm主人调教女m视频 | 国产一区二区三区网站 | 激情网五月天 | 自拍视频精品 | 久国产精品 | 亚洲 欧美 综合 | 成人一区二区电影 | av黄色在线| 超碰在线久 | 狠狠的干| 日韩不卡一区二区三区 | 综合久久99 | 欧美精品中文字幕久久二区 | 欧美成人精品一区二区男人看 | 成人免费视频网址 |