传入参数

举个栗子:根据id查name  参数:myid,定义方式和java中的函数类似,in 变量名 变量类型;

CREATE  PROCEDURE teste(in myid int)
BEGIN
declare myname VARCHAR(10) default \’\’;
select pname into myname from person where pid =myid;
select myname;
end

调用的时候直接call teste(2);

 

传出参数  out 变量名 类型

CREATE  PROCEDURE teste(in myid int,out myname varchar(10))
BEGIN
select pname into myname from person where pid =myid;
end

调用,当需要传入参数的时候,需要先设置传入参数,可以初始化一下,用于接收返回值。并且作为参数给函数使用

set @pname := \’\’;
call teste(2,@pname);
select @pname;

 

还有一些参数又是传入,还是传出参数,用inout定义

CREATE  PROCEDURE `teste`(inout myname varchar(10))
BEGIN
select CONCAT((select pname from person where pname = myname),”_来自地球”) into myname;
end

调用如下:

将能查到的name后加上来自地球这样的字符串。当然,一般存储过程中可以做更多操作。

 

版权声明:本文为liuyongbo原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/liuyongbo/p/11002969.html