一、创建存储过程
今天我们搞一搞MySQL的存储过程,过程中踩了一些小坑,算是做个总结归纳~
首先,我们了解一下存储过程的创建语句:
CREATE PROCEDURE `index_statistic`(IN `flag` varchar(10),OUT `result` int,INOUT `num` int)BEGINIF flag is not null THEN#查询语句SELECT COUNT(0) INTO resultFROMa_table t WHERE t.flag = flag;END IF;IF num is not null THEN#改变参数SELECT num*2 INTO num;set flag=true;END IF;END;
我们创建了一个名叫index_statistic的存储过程,它有三个参数,一个是输入参数flag,一个是输出参数result,一个输入输出参数num。
二、调用存储过程
我们开始调用我们刚才创建的存储过程:
set @flag='false'; #设置三个变量,用@符号区分这是变量set @result=1; set @num=1;call index_statistic(@flag,@result);#调用存储过程~注意参数位置应与定义时一一对应select @flag,@result,@@num;#查询变量值
运行结果如下(悠哈~):
参数类型
3种参数类型:
IN输入参数:表示调用者向过程传入值(传入值可以是字面量或变量)
OUT输出参数:表示过程向调用者传出值(可以返回多个值)(传出值只能是变量)
INOUT输入输出参数:既表示调用者向过程传入值,又表示过程向调用者传出值(值只能是变量)
三、结果分析
让我们来分析分析结果:
@flag参数是输入参数,在调用过程中,我们修改了@flag的值,但是调用完后,@flag仍是我们初始化时的值,因为IN传入参数不会改变传入的变量,@flag在我们此次调用中是局部变量!
@result是输出数,在调用时将查询结果存入了变量@result,结果@result也确实被改变了值,@result在我们此次调用中是全局变量!
@num是个输入输出参数,在存储过程调用期间,这种类型的变量的值是可以被修改的!