存储过程的参数


传入参数

举个栗子:根据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后加上来自地球这样的字符串。当然,一般存储过程中可以做更多操作。

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM