首頁 > 資料庫 > mysql教程 > mysql預存程序使用技巧有哪些

mysql預存程序使用技巧有哪些

coldplay.xixi
發布: 2020-10-20 15:58:41
原創
2524 人瀏覽過

mysql預存程序使用技巧有:1、建立帶in模式參數的預存程序;2、建立out模式參數的預存程序;3、建立帶inout模式參數的預存程序。

mysql預存程序使用技巧有哪些

mysql預存程序使用技巧有:

定義

一組預先編譯好的SQL語句的集合,理解成批次語句,類似java中的方法

1、提高程式碼的重用性

2、簡化運算

3、減少了編譯次數並且減少了和資料庫伺服器的連接次數,提高了效率

建立語法

CREATE PROCEDURE 存储过程名(参数列表)
BEGIN
存储过程体(一组合法的SQL语句)
END
登入後複製

參數清單包含三部分

參數模式參數名稱參數類型

範例:

in stuname varchar(20)
登入後複製

參數模式:

  • in:此參數可以作為輸入,也就是該參數需要呼叫方傳入值

  • out:此參數可以作為輸出,也就是該參數可以作為傳回值

  • inout:此參數既可以作為輸入又可以作為輸出,也就是該參數既需要傳入值,又可以傳回值

  • #如果儲存過程體只有一句話,begin end可以省略

  • 儲存過程體中的每個sql語句的結尾要求必須加分號。

  • 預存程序的結尾可以使用delimiter 重新設定

語法:

delimiter 结束标记
登入後複製

案例:

delimiter $
登入後複製

呼叫語法

CALL 存储过程名(实参列表);
登入後複製

#空參清單

插入到admin表中五筆記錄

SELECT * FROM admin;
DELIMITER $
CREATE PROCEDURE myp1()
BEGIN
INSERT INTO admin(username,`password`) 
VALUES('john1','0000'),('lily','0000'),('rose','0000'),('jack','0000'),('tom','0000');
END $
#调用
CALL myp1()$
登入後複製

建立帶有in模式參數的預存程序

创建存储过程实现 根据女神名,查询对应的男神信息
CREATE PROCEDURE myp2(IN beautyName VARCHAR(20))
BEGIN
SELECT bo.*
FROM boys bo
RIGHT JOIN beauty b ON bo.id = b.boyfriend_id
WHERE b.name=beautyName;
END $
#调用
CALL myp2('柳岩')$
登入後複製

#建立預存程序實現,使用者是否登入成功

CREATE PROCEDURE myp4(IN username VARCHAR(20),IN PASSWORD VARCHAR(20))
BEGIN
DECLARE result INT DEFAULT 0;#声明并初始化
SELECT COUNT(*) INTO result#赋值
FROM admin
WHERE admin.username = username
AND admin.password = PASSWORD;
SELECT IF(result>0,'成功','失败');#使用
END $
#调用
CALL myp3('张飞','8888')$
登入後複製

建立out 模式參數的預存程序

根據輸入的女神名,傳回對應的男神名

CREATE PROCEDURE myp6(IN beautyName VARCHAR(20),OUT boyName VARCHAR(20))
BEGIN
SELECT bo.boyname INTO boyname
FROM boys bo
RIGHT JOIN
beauty b ON b.boyfriend_id = bo.id
WHERE b.name=beautyName ;
END $
登入後複製

根據輸入的女神名,傳回對應的男神名和魅力值

CREATE PROCEDURE myp7(IN beautyName VARCHAR(20),OUT boyName VARCHAR(20),OUT usercp INT) 
BEGIN
SELECT boys.boyname ,boys.usercp INTO boyname,usercp
FROM boys 
RIGHT JOIN
beauty b ON b.boyfriend_id = boys.id
WHERE b.name=beautyName ;
END $
#调用
CALL myp7('小昭',@name,@cp)$
SELECT @name,@cp$
登入後複製

建立帶有inout模式參數的預存程序

傳入a和b兩個值,最後a和b都翻倍並回傳

CREATE PROCEDURE myp8(INOUT a INT ,INOUT b INT)
BEGIN
SET a=a*2;
SET b=b*2;
END $
#调用
SET @m=10$
SET @n=20$
CALL myp8(@m,@n)$
SELECT @m,@n$
登入後複製

#刪除預存程序

drop procedure 存储过程名
DROP PROCEDURE p1;
DROP PROCEDURE p2,p3;#×
登入後複製

查看預存程序的資訊

DESC myp2;
SHOW CREATE PROCEDURE  myp2;
登入後複製

以上是mysql預存程序使用技巧有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板