站長(zhǎng)資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        mysql中什么是存儲(chǔ)過程

        在mysql中,存儲(chǔ)過程是一組為了完成特定功能的SQL語句集合。使用存儲(chǔ)過程的目的是將常用或復(fù)雜的工作預(yù)先用SQL語句寫好并用一個(gè)指定名稱存儲(chǔ)起來,這個(gè)過程經(jīng)編譯和優(yōu)化后存儲(chǔ)在數(shù)據(jù)庫(kù)服務(wù)器中,因此稱為存儲(chǔ)過程。

        mysql中什么是存儲(chǔ)過程

        本教程操作環(huán)境:windows7系統(tǒng)、mysql8版本、Dell G3電腦。

        存儲(chǔ)過程(Stored Procedure)是一種在數(shù)據(jù)庫(kù)中存儲(chǔ)復(fù)雜程序,以便外部程序調(diào)用的一種數(shù)據(jù)庫(kù)對(duì)象。

        存儲(chǔ)過程是一組為了完成特定功能的 SQL 語句集合。使用存儲(chǔ)過程的目的是將常用或復(fù)雜的工作預(yù)先用 SQL 語句寫好并用一個(gè)指定名稱存儲(chǔ)起來,這個(gè)過程經(jīng)編譯和優(yōu)化后存儲(chǔ)在數(shù)據(jù)庫(kù)服務(wù)器中,因此稱為存儲(chǔ)過程。當(dāng)以后需要數(shù)據(jù)庫(kù)提供與已定義好的存儲(chǔ)過程的功能相同的服務(wù)時(shí),只需調(diào)用“CALL存儲(chǔ)過程名字”即可自動(dòng)完成。

        常用操作數(shù)據(jù)庫(kù)的 SQL 語句在執(zhí)行的時(shí)候需要先編譯,然后執(zhí)行。存儲(chǔ)過程則采用另一種方式來執(zhí)行 SQL 語句。

        一個(gè)存儲(chǔ)過程是一個(gè)可編程的函數(shù),它在數(shù)據(jù)庫(kù)中創(chuàng)建并保存,一般由 SQL 語句和一些特殊的控制結(jié)構(gòu)組成。當(dāng)希望在不同的應(yīng)用程序或平臺(tái)上執(zhí)行相同的特定功能時(shí),存儲(chǔ)過程尤為合適。

        MySQL 5.0 版本以前并不支持存儲(chǔ)過程,這使 MySQL 在應(yīng)用上大打折扣。MySQL 從 5.0 版本開始支持存儲(chǔ)過程,既提高了數(shù)據(jù)庫(kù)的處理速度,同時(shí)也提高了數(shù)據(jù)庫(kù)編程的靈活性

        存儲(chǔ)過程是數(shù)據(jù)庫(kù)中的一個(gè)重要功能,存儲(chǔ)過程可以用來轉(zhuǎn)換數(shù)據(jù)、數(shù)據(jù)遷移、制作報(bào)表,它類似于編程語言,一次執(zhí)行成功,就可以隨時(shí)被調(diào)用,完成指定的功能操作。

        使用存儲(chǔ)過程不僅可以提高數(shù)據(jù)庫(kù)的訪問效率,同時(shí)也可以提高數(shù)據(jù)庫(kù)使用的安全性。

        對(duì)于調(diào)用者來說,存儲(chǔ)過程封裝了 SQL 語句,調(diào)用者無需考慮邏輯功能的具體實(shí)現(xiàn)過程。只是簡(jiǎn)單調(diào)用即可,它可以被 Java 和 C# 等編程語言調(diào)用。

        創(chuàng)建存儲(chǔ)過程

        可以使用 CREATE PROCEDURE 語句創(chuàng)建存儲(chǔ)過程,語法格式如下:

        CREATE PROCEDURE <過程名> ( [過程參數(shù)[,…] ] ) <過程體>

        [過程參數(shù)[,…] ] 格式

        [ IN | OUT | INOUT ] <參數(shù)名> <類型>

        語法說明如下:

        1) 過程名

        存儲(chǔ)過程的名稱,默認(rèn)在當(dāng)前數(shù)據(jù)庫(kù)中創(chuàng)建。若需要在特定數(shù)據(jù)庫(kù)中創(chuàng)建存儲(chǔ)過程,則要在名稱前面加上數(shù)據(jù)庫(kù)的名稱,即 db_name.sp_name。

        需要注意的是,名稱應(yīng)當(dāng)盡量避免選取與 MySQL 內(nèi)置函數(shù)相同的名稱,否則會(huì)發(fā)生錯(cuò)誤。

        2) 過程參數(shù)

        存儲(chǔ)過程的參數(shù)列表。其中,<參數(shù)名>為參數(shù)名,<類型>為參數(shù)的類型(可以是任何有效的 MySQL 數(shù)據(jù)類型)。當(dāng)有多個(gè)參數(shù)時(shí),參數(shù)列表中彼此間用逗號(hào)分隔。存儲(chǔ)過程可以沒有參數(shù)(此時(shí)存儲(chǔ)過程的名稱后仍需加上一對(duì)括號(hào)),也可以有 1 個(gè)或多個(gè)參數(shù)。

        MySQL 存儲(chǔ)過程支持三種類型的參數(shù),即輸入?yún)?shù)、輸出參數(shù)和輸入/輸出參數(shù),分別用 IN、OUT 和 INOUT 三個(gè)關(guān)鍵字標(biāo)識(shí)。其中,輸入?yún)?shù)可以傳遞給一個(gè)存儲(chǔ)過程,輸出參數(shù)用于存儲(chǔ)過程需要返回一個(gè)操作結(jié)果的情形,而輸入/輸出參數(shù)既可以充當(dāng)輸入?yún)?shù)也可以充當(dāng)輸出參數(shù)。

        需要注意的是,參數(shù)的取名不要與數(shù)據(jù)表的列名相同,否則盡管不會(huì)返回出錯(cuò)信息,但是存儲(chǔ)過程的 SQL 語句會(huì)將參數(shù)名看作列名,從而引發(fā)不可預(yù)知的結(jié)果。

        3) 過程體

        存儲(chǔ)過程的主體部分,也稱為存儲(chǔ)過程體,包含在過程調(diào)用的時(shí)候必須執(zhí)行的 SQL 語句。這個(gè)部分以關(guān)鍵字 BEGIN 開始,以關(guān)鍵字 END 結(jié)束。若存儲(chǔ)過程體中只有一條 SQL 語句,則可以省略 BEGIN-END 標(biāo)志。

        示例:

        創(chuàng)建名稱為 ShowStuScore 的存儲(chǔ)過程,存儲(chǔ)過程的作用是從學(xué)生成績(jī)信息表中查詢學(xué)生的成績(jī)信息,輸入的 SQL 語句和執(zhí)行過程如下所示。

        mysql> DELIMITER // mysql> CREATE PROCEDURE ShowStuScore()     -> BEGIN     -> SELECT * FROM tb_students_score;     -> END // Query OK, 0 rows affected (0.09 sec)

        結(jié)果顯示 ShowStuScore 存儲(chǔ)過程已經(jīng)創(chuàng)建成功。

        刪除存儲(chǔ)過程

        存儲(chǔ)過程被創(chuàng)建后,就會(huì)一直保存在數(shù)據(jù)庫(kù)服務(wù)器上,直至被刪除。當(dāng) MySQL 數(shù)據(jù)庫(kù)中存在廢棄的存儲(chǔ)過程時(shí),我們需要將它從數(shù)據(jù)庫(kù)中刪除。

        MySQL 中使用 DROP PROCEDURE 語句來刪除數(shù)據(jù)庫(kù)中已經(jīng)存在的存儲(chǔ)過程。語法格式如下:

        DROP PROCEDURE [ IF EXISTS ] <過程名>

        語法說明如下:

        • 過程名:指定要?jiǎng)h除的存儲(chǔ)過程的名稱。

        • IF EXISTS:指定這個(gè)關(guān)鍵字,用于防止因刪除不存在的存儲(chǔ)過程而引發(fā)的錯(cuò)誤。

        注意:存儲(chǔ)過程名稱后面沒有參數(shù)列表,也沒有括號(hào),在刪除之前,必須確認(rèn)該存儲(chǔ)過程沒有任何依賴關(guān)系,否則會(huì)導(dǎo)致其他與之關(guān)聯(lián)的存儲(chǔ)過程無法運(yùn)行。

        實(shí)例

        下面刪除存儲(chǔ)過程 ShowStuScore,SQL 語句和運(yùn)行結(jié)果如下:

        mysql> DROP PROCEDURE ShowStuScore; Query OK, 0 rows affected (0.08 sec)

        刪除后,可以通過查詢 information_schema 數(shù)據(jù)庫(kù)下的 routines 表來確認(rèn)上面的刪除是否成功。SQL 語句和運(yùn)行結(jié)果如下:

        mysql> SELECT * FROM information_schema.routines WHERE routine_name='ShowStuScore'; Empty set (0.03 sec)

        結(jié)果顯示,沒有查詢出任何記錄,說明存儲(chǔ)過程 ShowStuScore 已經(jīng)被刪除了。

        (推薦教程:mysql視頻教程)

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
        主站蜘蛛池模板: 国产精品毛片无遮挡| 51久久夜色精品国产| 欧美精品免费线视频观看视频| 四虎成人精品| 91精品国产91热久久久久福利| 精品少妇无码AV无码专区| 欧美精品一区二区久久| 国产成人精品福利网站在线观看| 久久精品亚洲中文字幕无码麻豆| 人妻少妇看A偷人无码精品视频 | 国产精品日韩深夜福利久久| 国产AV无码专区亚洲精品| 四虎国产精品永久在线观看| 青草青草久热精品视频在线观看| 国产精品无码久久久久| 亚洲第一精品在线视频| 99久久国产热无码精品免费| 男女男精品视频网站在线观看| 国产国拍亚洲精品mv在线观看| 亚洲精品高清一二区久久| 精品亚洲欧美无人区乱码| 国产精品一区12p| 国产精品 91 第一页| 99久久精品免费看国产一区二区三区 | 国产成人亚洲精品青草天美| 久久精品国产亚洲AV无码娇色| 一本一本久久A久久综合精品| 亚洲精品视频久久久| 四虎精品成人免费视频| 欧美精品在线免费| 四虎国产精品永久在线无码| 日本精品久久久久久久久免费| 久久丝袜精品中文字幕| 午夜成人精品福利网站在线观看| 四虎永久在线精品免费一区二区| 日本精品视频在线观看| 无码人妻精品一区二区三区99不卡 | 99久久精品无码一区二区毛片 | 国产精品嫩草影院一二三区入口| 996久久国产精品线观看| 999精品在线|