MySQL创建、调用存储过程

一、创建存储过程

今天我们搞一搞MySQL的存储过程,过程中踩了一些小坑,算是做个总结归纳~

首先,我们了解一下存储过程的创建语句:

CREATE PROCEDURE `index_statistic`(IN `flag` varchar(10),OUT `result` int,INOUT `num` int)
BEGIN
	IF flag is not null THEN
		#查询语句
		SELECT 
			COUNT(0) INTO result
		FROM
			a_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是个输入输出参数,在存储过程调用期间,这种类型的变量的值是可以被修改的!

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值