5.带out模式的存储过程
1)案例1:创建一个存储过程,根据女神姓名,返回对应的男神姓名
-- 创建一个存储过程 delimiter $ create procedure myp4(in beautyName varchar(20),out boyName varchar(20)) begin select b.boyName into boyName from beauty left join boys b on beauty.boyfriend_id=b.id where beauty.name=beautyName; end $ -- 调用 # 重新定义一个变量@boyname接收返回值boyName。 call myp4("赵敏",@boyname)$ select @boyname$ call myp4("柳岩",@boyname)$ select @boyname$
结果如下:
2)案例2:创建一个存储过程,根据女神名,返回对应的男神名和男神魅力值
-- 创建一个存储过程 delimiter $ create procedure myp5(in beautyName varchar(20),out boyName varchar(20),out userCP int) begin select b.boyName,b.userCP into boyName,userCP from beauty left join boys b on beauty.boyfriend_id=b.id where beauty.name=beautyName; end $ -- 调用 # 重新定义一个变量@boyname接收返回值boyName。 call myp5("赵敏",@boyname,@usercp)$ select @boyname,@usercp$ call myp5("柳岩",@boyname,@usercp)$ select @boyname,@usercp$
结果如下:
6.带inout模式的存储过程
1)案例1:传入a和b两个值,最终a和b都翻倍并返回。
-- 创建一个存储过程 delimiter $ create procedure myp6(inout a int ,inout b int) begin -- 局部变量不用加@符号。 set a=a*2; set b=b*2; end $ -- 调用 -- 特别注意调用这一块儿。 set @m=10$ set @n=20$ call myp6(@m,@n)$ select @m,@n$
结果如下: