新聞中心
MySQL 存儲過程是一些 SQL 語句的集合,比如有時候我們可能需要一大串的 SQL 語句,或者說在編寫 SQL 語句的過程中需要設置一些變量的值,這個時候我們就完全有必要編寫一個存儲過程。

創(chuàng)新互聯(lián)公司專注于企業(yè)網(wǎng)絡營銷推廣、網(wǎng)站重做改版、銅鼓網(wǎng)站定制設計、自適應品牌網(wǎng)站建設、成都h5網(wǎng)站建設、成都商城網(wǎng)站開發(fā)、集團公司官網(wǎng)建設、外貿營銷網(wǎng)站建設、高端網(wǎng)站制作、響應式網(wǎng)頁設計等建站業(yè)務,價格優(yōu)惠性價比高,為銅鼓等各大城市提供網(wǎng)站開發(fā)制作服務。
編寫存儲過程并不是件簡單的事情,但是使用存儲過程可以簡化操作,且減少冗余的操作步驟,同時,還可以減少操作過程中的失誤,提高效率,因此應該盡可能的學會使用存儲過程。
下面主要介紹如何創(chuàng)建存儲過程。
可以使用
CREATE PROCEDURE 語句創(chuàng)建存儲過程,語法格式如下:
CREATE PROCEDURE <過程名> ( [過程參數(shù)[,…] ] ) <過程體>
[過程參數(shù)[,…] ] 格式
[ IN | OUT | INOUT ] <參數(shù)名> <類型>
語法說明如下:
1) 過程名
存儲過程的名稱,默認在當前數(shù)據(jù)庫中創(chuàng)建。若需要在特定數(shù)據(jù)庫中創(chuàng)建存儲過程,則要在名稱前面加上數(shù)據(jù)庫的名稱,即 db_name.sp_name。
需要注意的是,名稱應當盡量避免選取與 MySQL 內置函數(shù)相同的名稱,否則會發(fā)生錯誤。
2) 過程參數(shù)
存儲過程的參數(shù)列表。其中,
<參數(shù)名>為參數(shù)名,
<類型>為參數(shù)的類型(可以是任何有效的 MySQL 數(shù)據(jù)類型)。當有多個參數(shù)時,參數(shù)列表中彼此間用逗號分隔。存儲過程可以沒有參數(shù)(此時存儲過程的名稱后仍需加上一對括號),也可以有 1 個或多個參數(shù)。
MySQL 存儲過程支持三種類型的參數(shù),即輸入?yún)?shù)、輸出參數(shù)和輸入/輸出參數(shù),分別用 IN、OUT 和 INOUT 三個關鍵字標識。其中,輸入?yún)?shù)可以傳遞給一個存儲過程,輸出參數(shù)用于存儲過程需要返回一個操作結果的情形,而輸入/輸出參數(shù)既可以充當輸入?yún)?shù)也可以充當輸出參數(shù)。
需要注意的是,參數(shù)的取名不要與數(shù)據(jù)表的列名相同,否則盡管不會返回出錯信息,但是存儲過程的 SQL 語句會將參數(shù)名看作列名,從而引發(fā)不可預知的結果。
3) 過程體
存儲過程的主體部分,也稱為存儲過程體,包含在過程調用的時候必須執(zhí)行的 SQL 語句。這個部分以關鍵字
BEGIN 開始,以關鍵字
END 結束。若存儲過程體中只有一條 SQL 語句,則可以省略 BEGIN-END 標志。
在存儲過程的創(chuàng)建中,經常會用到一個十分重要的 MySQL 命令,即 DELIMITER 命令,特別是對于通過命令行的方式來操作 MySQL 數(shù)據(jù)庫的使用者,更是要學會使用該命令。
在 MySQL 中,服務器處理 SQL 語句默認是以分號作為語句結束標志的。然而,在創(chuàng)建存儲過程時,存儲過程體可能包含有多條 SQL 語句,這些 SQL 語句如果仍以分號作為語句結束符,那么 MySQL 服務器在處理時會以遇到的第一條 SQL 語句結尾處的分號作為整個程序的結束符,而不再去處理存儲過程體中后面的 SQL 語句,這樣顯然不行。
為解決以上問題,通常使用
DELIMITER 命令將結束命令修改為其他字符。語法格式如下:
DELIMITER $$
語法說明如下:
- $$ 是用戶定義的結束符,通常這個符號可以是一些特殊的符號,如兩個“?”或兩個“¥”等。
- 當使用 DELIMITER 命令時,應該避免使用反斜杠“\”字符,因為它是 MySQL 的轉義字符。
在 MySQL 命令行客戶端輸入如下 SQL 語句。
mysql > DELIMITER ??
成功執(zhí)行這條 SQL 語句后,任何命令、語句或程序的結束標志就換為兩個問號“??”了。
若希望換回默認的分號“;”作為結束標志,則在 MySQL 命令行客戶端輸入下列語句即可:
mysql > DELIMITER ;
注意:
DELIMITER 和分號“;”之間一定要有一個空格。在創(chuàng)建存儲過程時,必須具有 CREATE ROUTINE 權限。
例 1
創(chuàng)建名稱為 ShowStuScore 的存儲過程,存儲過程的作用是從學生成績信息表中查詢學生的成績信息,輸入的 SQL 語句和執(zhí)行過程如下所示。
mysql> DELIMITER //
mysql> CREATE PROCEDURE ShowStuScore()
-> BEGIN
-> SELECT * FROM tb_students_score;
-> END //
Query OK, 0 rows affected (0.09 sec) 結果顯示 ShowStuScore 存儲過程已經創(chuàng)建成功。
例 2
創(chuàng)建名稱為 GetScoreByStu 的存儲過程,輸入?yún)?shù)是學生姓名。存儲過程的作用是通過輸入的學生姓名從學生成績信息表中查詢指定學生的成績信息,輸入的 SQL 語句和執(zhí)行過程如下所示。
mysql> DELIMITER //
mysql> CREATE PROCEDURE GetScoreByStu
-> (IN name VARCHAR(30))
-> BEGIN
-> SELECT student_score FROM tb_students_score
-> WHERE student_name=name;
-> END //
Query OK, 0 rows affected (0.01 sec) 網(wǎng)站欄目:創(chuàng)新互聯(lián)數(shù)據(jù)庫教程:MySQL創(chuàng)建存儲過程(CREATEPROCEDURE)
網(wǎng)頁路徑:http://www.dlmjj.cn/article/dpsjhpg.html


咨詢
建站咨詢
