国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

MySQL存儲(chǔ)過(guò)程詳解 mysql 存儲(chǔ)步驟

2024-07-24 12:32:06
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
         mysql存儲(chǔ)過(guò)程詳解
 
1.      存儲(chǔ)過(guò)程簡(jiǎn)介
 
      我們常用的操作數(shù)據(jù)庫(kù)語(yǔ)言SQL語(yǔ)句在執(zhí)行的時(shí)候需要要先編譯,然后執(zhí)行,而存儲(chǔ)過(guò)程(Stored Procedure)是一組為了完成特定功能的SQL語(yǔ)句集,經(jīng)編譯后存儲(chǔ)在數(shù)據(jù)庫(kù)中,用戶通過(guò)指定存儲(chǔ)過(guò)程的名字并給定參數(shù)(如果該存儲(chǔ)過(guò)程帶有參數(shù))來(lái)調(diào)用執(zhí)行它。
       一個(gè)存儲(chǔ)過(guò)程是一個(gè)可編程的函數(shù),它在數(shù)據(jù)庫(kù)中創(chuàng)建并保存。它可以有SQL語(yǔ)句和一些特殊的控制結(jié)構(gòu)組成。當(dāng)希望在不同的應(yīng)用程序或平臺(tái)上執(zhí)行相同的函數(shù),或者封裝特定功能時(shí),存儲(chǔ)過(guò)程是非常有用的。數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程可以看做是對(duì)編程中面向?qū)ο蠓椒ǖ哪M。它允許控制數(shù)據(jù)的訪問(wèn)方式。
     存儲(chǔ)過(guò)程通常有以下優(yōu)點(diǎn):
     (1).存儲(chǔ)過(guò)程增強(qiáng)了SQL語(yǔ)言的功能和靈活性。存儲(chǔ)過(guò)程可以用流控制語(yǔ)句編寫,有很強(qiáng)的靈活性,可以完成復(fù)雜的判斷和較復(fù)雜的運(yùn)算。
     (2). 存儲(chǔ)過(guò)程可被作為一種安全機(jī)制來(lái)充分利用。系統(tǒng)管理員通過(guò)執(zhí)行某一存儲(chǔ)過(guò)程的權(quán)限進(jìn)行限制,能夠?qū)崿F(xiàn)對(duì)相應(yīng)的數(shù)據(jù)的訪問(wèn)權(quán)限的限制,避免了非授權(quán)用戶對(duì)數(shù)據(jù)的訪問(wèn),保證了數(shù)據(jù)的安全。
 
2.      關(guān)于MySQL的存儲(chǔ)過(guò)程
存儲(chǔ)過(guò)程是數(shù)據(jù)庫(kù)存儲(chǔ)的一個(gè)重要的功能,但是MySQL在5.0以前并不支持存儲(chǔ)過(guò)程,這使得MySQL在應(yīng)用上大打折扣。好在MySQL 5.0終于開(kāi)始已經(jīng)支持存儲(chǔ)過(guò)程,這樣即可以大大提高數(shù)據(jù)庫(kù)的處理速度,同時(shí)也可以提高數(shù)據(jù)庫(kù)編程的靈活性。
 
3.      MySQL存儲(chǔ)過(guò)程的創(chuàng)建
(1). 格式
MySQL存儲(chǔ)過(guò)程創(chuàng)建的格式:CREATE PROCEDURE 過(guò)程名 ([過(guò)程參數(shù)[,...]])
[特性 ...] 過(guò)程體
這里先舉個(gè)例子:
1. mysql> DELIMITER //  
2. mysql> CREATE PROCEDURE proc1(OUT s int)  
3.    -> BEGIN
4.    -> SELECT COUNT(*) INTO s FROM user;  
5.    -> END
6.    -> //  
7. mysql> DELIMITER ;
 
注:
(1)這里需要注意的是DELIMITER //和DELIMITER ;兩句,DELIMITER是分割符的意思,因?yàn)镸ySQL默認(rèn)以";"為分隔符,如果我們沒(méi)有聲明分割符,那么編譯器會(huì)把存儲(chǔ)過(guò)程當(dāng)成SQL語(yǔ)句進(jìn)行處理,則存儲(chǔ)過(guò)程的編譯過(guò)程會(huì)報(bào)錯(cuò),所以要事先用DELIMITER關(guān)鍵字申明當(dāng)前段分隔符,這樣MySQL才會(huì)將";"當(dāng)做存儲(chǔ)過(guò)程中的代碼,不會(huì)執(zhí)行這些代碼,用完了之后要把分隔符還原。
(2)存儲(chǔ)過(guò)程根據(jù)需要可能會(huì)有輸入、輸出、輸入輸出參數(shù),這里有一個(gè)輸出參數(shù)s,類型是int型,如果有多個(gè)參數(shù)用","分割開(kāi)。
(3)過(guò)程體的開(kāi)始與結(jié)束使用BEGIN與END進(jìn)行標(biāo)識(shí)。
這樣,我們的一個(gè)MySQL存儲(chǔ)過(guò)程就完成了,是不是很容易呢?看不懂也沒(méi)關(guān)系,接下來(lái),我們?cè)敿?xì)的講解。
 
Ⅰ. 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. +------+  
10. | p_in |  
11. +------+  
12. |   2  |   
13. +------+  
14.  
15. mysql> SELECT @p_in;  
16. +-------+  
17. | @p_in |  
18. +-------+  
19. |  1    |  
20. +-------+  
 
 
以上可以看出,p_in雖然在存儲(chǔ)過(guò)程中被修改,但并不影響@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. +-------+  
10. | p_out |  
11. +-------+  
12. |   2   |   
13. +-------+  
14.  
15. mysql> SELECT @p_out;  
16. +-------+  
17. | p_out |  
18. +-------+  
19. |   2   |  
20. +-------+  
 
 
Ⅲ. 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 ;
 
(4). 變量
 在存儲(chǔ)過(guò)程間傳遞全局范圍的用戶變量
 
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. +-----------------------------------------------+  

(編輯:武林網(wǎng))

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 凌海市| 河南省| 峡江县| 天镇县| 图们市| 泗水县| 和硕县| 和林格尔县| 颍上县| 皋兰县| 大冶市| 海南省| 青田县| 双牌县| 蒙山县| 湖口县| 交城县| 隆化县| 屯昌县| 博乐市| 新余市| 进贤县| 舟曲县| 克东县| 海原县| 常州市| 镇原县| 太湖县| 安龙县| 裕民县| 留坝县| 安顺市| 叙永县| 呼和浩特市| 抚顺市| 郁南县| 兴文县| 灵台县| 库尔勒市| 林甸县| 莒南县|