自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

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

[[244976]]

圖片來自包圖網(wǎng)

1. 存儲過程簡介

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

一個存儲過程是一個可編程的函數(shù),它在數(shù)據(jù)庫中創(chuàng)建并保存。它可以有SQL語句和一些特殊的控制結(jié)構(gòu)組成。當(dāng)希望在不同的應(yīng)用程序或平臺上執(zhí)行相同的函數(shù),或者封裝特定功能時,存儲過程是非常有用的。數(shù)據(jù)庫中的存儲過程可以看做是對編程中面向?qū)ο蠓椒ǖ哪M。它允許控制數(shù)據(jù)的訪問方式。

存儲過程通常有以下優(yōu)點:

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

(2).存儲過程允許標(biāo)準(zhǔn)組件是編程。存儲過程被創(chuàng)建后,可以在程序中被多次調(diào)用,而不必重新編寫該存儲過程的SQL語句。而且數(shù)據(jù)庫專業(yè)人員可以隨時對存儲過程進(jìn)行修改,對應(yīng)用程序源代碼毫無影響。

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

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

(5).存儲過程可被作為一種安全機(jī)制來充分利用。系統(tǒng)管理員通過執(zhí)行某一存儲過程的權(quán)限進(jìn)行限制,能夠?qū)崿F(xiàn)對相應(yīng)的數(shù)據(jù)的訪問權(quán)限的限制,避免了非授權(quán)用戶對數(shù)據(jù)的訪問,保證了數(shù)據(jù)的安全。

2. 關(guān)于MySQL的存儲過程

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

3. MySQL存儲過程的創(chuàng)建

(1). 格式

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

[特性 ...] 過程體

這里先舉個例子

  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默認(rèn)以";"為分隔符,如果我們沒有聲明分割符,那么編譯器會把存儲過程當(dāng)成SQL語句進(jìn)行處理,則存儲過程的編譯過程會報錯,所以要事先用DELIMITER關(guān)鍵字申明當(dāng)前段分隔符,這樣MySQL才會將";"當(dāng)做存儲過程中的代碼,不會執(zhí)行這些代碼,用完了之后要把分隔符還原。
  2. 存儲過程根據(jù)需要可能會有輸入、輸出、輸入輸出參數(shù),這里有一個輸出參數(shù)s,類型是int型,如果有多個參數(shù)用","分割開。
  3. 過程體的開始與結(jié)束使用BEGIN與END進(jìn)行標(biāo)識。

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

(2). 聲明分割符

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

(3). 參數(shù)

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

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

IN 輸入?yún)?shù):表示該參數(shù)的值必須在調(diào)用存儲過程時指定,在存儲過程中修改該參數(shù)的值不能被返回,為默認(rèn)值

OUT 輸出參數(shù):該值可在存儲過程內(nèi)部被改變,并可返回

INOUT 輸入輸出參數(shù):調(diào)用時指定,并且可被改變和返回

Ⅰ. IN參數(shù)例子

創(chuàng)建:

  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 ; 

執(zhí)行結(jié)果:

  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參數(shù)例子

創(chuàng)建:

  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 ; 

執(zhí)行結(jié)果:

  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參數(shù)例子

創(chuàng)建:

  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 ; 

執(zhí)行結(jié)果:

  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的數(shù)據(jù)類型,如: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 變量名 = 表達(dá)式值 [,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. +-----------------------------------------------+ 
責(zé)任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2023-05-12 09:08:48

TypeScript工具類型

2020-09-21 08:33:12

線程池調(diào)度Thread Pool

2020-04-15 08:33:43

Netty網(wǎng)絡(luò)通信

2021-07-15 09:55:47

systemdLinux文件

2020-03-27 09:06:54

選擇排序算法冒泡排序

2021-05-14 07:11:49

方法調(diào)用類加載

2022-08-15 19:49:57

Consul架構(gòu)注冊中心

2022-05-29 22:55:00

適配器設(shè)計模式

2021-12-30 09:10:28

游戲開發(fā)開發(fā)技術(shù)熱點

2019-08-14 10:20:32

算法數(shù)組鏈表

2019-01-15 09:55:24

RAID磁盤陣列數(shù)據(jù)存儲

2020-05-09 14:40:29

UI設(shè)計開發(fā)

2025-03-04 02:00:00

Python編寫自動化

2015-07-21 13:07:14

Reactjs教程

2024-12-12 08:22:03

負(fù)載均衡算法無狀態(tài)

2024-11-20 16:02:47

.NET 9LINQ開發(fā)

2021-01-07 10:30:23

設(shè)計模式

2021-05-13 07:30:27

Kafka消息流系統(tǒng)

2019-08-22 09:22:44

數(shù)據(jù)結(jié)構(gòu)二叉搜索樹

2020-11-26 10:33:44

MySQL存儲函數(shù)
點贊
收藏

51CTO技術(shù)棧公眾號