日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL数据库:存储过程Procedure

發(fā)布時間:2024/9/30 数据库 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL数据库:存储过程Procedure 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?

一、存儲過程:

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

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

1、為什么需要存儲過程:

有人說,不需要把復雜過程封裝成MySQL存儲過程,用程序(C++/JAVA)也能實現(xiàn)復雜邏輯。如果用程序調(diào)用API執(zhí)行,其實效率相對較慢,原因在于你的應(yīng)用程序要通過引擎把MySQL語句交付給MySQL引擎來執(zhí)行,那就不如直接讓MySQL負責它最精通最能夠完成的工作,所以可以在開發(fā)中可以將某些常用的操作封裝成存儲過程。

2、存儲過程和自定義函數(shù)的區(qū)別:

(1)存儲過程實現(xiàn)的功能要復雜一些,而函數(shù)的針對性更強;

(2)存儲過程可以返回多個值,函數(shù)只能有一個返回值;

(3)存儲過程一般獨立的來執(zhí)行;而函數(shù)可以作為其他SQL語句的組成部分來實現(xiàn)。

?

二、存儲過程的優(yōu)點:

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

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

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

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

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

?

三、MySQL存儲過程的相關(guān)操作:

1、存儲過程的創(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 ;

(1)分隔符:MySQL默認以";"為分隔符,如果沒有聲明分割符,則編譯器會把存儲過程當成SQL語句進行處理,因此編譯過程會報錯,所以要事先用“DELIMITER //”聲明當前段分隔符,讓編譯器把兩個"//"之間的內(nèi)容當做存儲過程的代碼,不會執(zhí)行這些代碼;“DELIMITER ;”的意為把分隔符還原。

(2)參數(shù):存儲過程根據(jù)需要可能會有輸入、輸出、輸入輸出參數(shù),如果有多個參數(shù)用","分割開。MySQL存儲過程的參數(shù)用在存儲過程的定義,共有三種參數(shù)類型,IN,OUT,INOUT:

IN:參數(shù)的值必須在調(diào)用存儲過程時指定,在存儲過程中修改該參數(shù)的值不能被返回,為默認值

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

INOUT:調(diào)用時指定,并且可被改變和返回

(3)過程體:過程體的開始與結(jié)束使用BEGIN與END進行標識。

2、MySQL存儲過程的調(diào)用:

用call和你過程名以及一個括號,括號里面根據(jù)需要,加入?yún)?shù),參數(shù)包括輸入?yún)?shù)、輸出參數(shù)、輸入輸出參數(shù)。

3、MySQL存儲過程的查詢信息:

?#查詢存儲過程:

SELECT name FROM mysql.proc WHERE db='數(shù)據(jù)庫名';

SELECT routine_name FROM information_schema.routines WHERE routine_schema='數(shù)據(jù)庫名';

SHOW PROCEDURE STATUS WHERE db='數(shù)據(jù)庫名';

#查看存儲過程的定義:

SHOW CREATE PROCEDURE 數(shù)據(jù)庫.存儲過程名;

#查看狀態(tài):

SHOW [PROCEDURE|FUNCTION] STATUS [LIKE 'pattern']

4、MySQL存儲過程的修改:

使用ALTER PROCEDURE 更改用CREATE PROCEDURE 建立的預先指定的存儲過程,其不會影響相關(guān)存儲過程或存儲功能。

ALTER {PROCEDURE | FUNCTION} sp_name [characteristic ...]

characteristic:

{ CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
| SQL SECURITY { DEFINER | INVOKER }
| COMMENT 'string'

(1)sp_name參數(shù)表示存儲過程或函數(shù)的名稱;

(2)characteristic參數(shù)指定存儲函數(shù)的特性。

(3)CONTAINS SQL表示子程序包含SQL語句,但不包含讀或?qū)憯?shù)據(jù)的語句;

(4)NO SQL表示子程序中不包含SQL語句;

(5)READS SQL DATA表示子程序中包含讀數(shù)據(jù)的語句;

(6)MODIFIES SQL DATA表示子程序中包含寫數(shù)據(jù)的語句。

(7)SQL SECURITY { DEFINER | INVOKER }指明誰有權(quán)限來執(zhí)行,DEFINER表示只有定義者自己才能夠執(zhí)行;INVOKER表示調(diào)用者可以執(zhí)行。

(8)COMMENT 'string'是注釋信息。

實例:

#將讀寫權(quán)限改為MODIFIES SQL DATA,并指明調(diào)用者可以執(zhí)行。

ALTER ?PROCEDURE ?num_from_employee
? MODIFIES SQL DATA
??SQL SECURITY INVOKER ;
#將讀寫權(quán)限改為READS SQL DATA,并加上注釋信息'FIND NAME'。
ALTER ?PROCEDURE ?name_from_employee
??READS SQL DATA
??COMMENT 'FIND NAME' ;

5、MySQL存儲過程的刪除:

#從MySQL的表格中刪除一個或多個存儲過程。

DROP PROCEDURE [過程1[,過程2…]]

?

?

其他更多的有關(guān)存儲引擎的操作可以參考這篇文章:

https://www.cnblogs.com/mark-chan/p/5384139.html

總結(jié)

以上是生活随笔為你收集整理的MySQL数据库:存储过程Procedure的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。