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

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

coldplay.xixi
coldplay.xixi原創
2020-10-20 15:58:412468瀏覽

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn