1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > MySQL创建 调用存储过程

MySQL创建 调用存储过程

时间:2021-10-09 23:39:57

相关推荐

MySQL创建 调用存储过程

一、创建存储过程

今天我们搞一搞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是个输入输出参数,在存储过程调用期间,这种类型的变量的值是可以被修改的!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。