mysql存储过程的in,out,inout

  1. -- 创建测试存储过程

  2. delimiter //
  3. create procedure p_in ( IN num int )
  4. begin
  5.     select num;
  6.     set num=100;
  7.     select num;
  8. end;
  9. //
  10. delimiter ;

我设置用户变量@num为1,将@num传入p_in过程之中:

mysql> set @num=1;

Query OK, 0 rows affected (0.00 sec)

mysql> call p_in(@num);

+------+

| num  |

+------+

|    1   |

+------+

1 row in set (0.00 sec)

+------+

| num  |

+------+

|  100  |

+------+

1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

此时再次查询@num发现@num仍为1:
mysql> select @num;

+------+

| @num |

+------+

|    1   |

+------+

1 row in set (0.00 sec)

所以 IN 参数只是将变量在存储过程内部做了修改,并没有影响到外部,@num仍为1。




OUT 参数:


  1. -- 创建测试存储过程

  2. delimiter //
  3. create procedure p_out ( OUT num int )
  4. begin
  5.     select num;
  6.     set num=100;
  7.     select num;
  8. end;
  9. //

  10. delimiter ;

我设置@num为1,并调用p_out:

mysql> set @num=1;

Query OK, 0 rows affected (0.00 sec)

mysql> call p_out(@num);

+------+

| num  |

+------+

| NULL |

+------+

1 row in set (0.00 sec)

+------+

| num  |

+------+

|  100 |

+------+

1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

此时发现,过程的第一个select num为NULL,意味着@num无论是否有传入的外部值,其初始值在过程内都为NULL。

再次查看@num值,发现之前即使我已经set @num=1,但是在存储过程的调用下,仍然被修改为100,说明OUT参数将参数值传回给调用者。

mysql> select @num;

+------+

| @num |

+------+

|  100 |

+------+

1 row in set (0.00 sec)




INOUT 参数:

  1. -- 创建测试存储过程

  2. delimiter //
  3. create procedure p_inout ( INOUT num int )
  4. begin
  5.     select num;
  6.     set num=100;
  7.     select num;
  8. end;
  9. //

  10. delimiter ;

同样的,我首先将@num置为1,并调用p_inout:

mysql> set @num=1;

Query OK, 0 rows affected (0.00 sec)

mysql> call p_inout(@num);

+------+

| num  |

+------+

|    1   |

+------+

1 row in set (0.00 sec)

+------+

| num  |

+------+

|  100 |

+------+

1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)
发现返回结果与p_in一致,说明@num为1的值,已经传入存储过程。

再次查询调用过程后的@num,发现@num为100,此时又与p_out一致,同样,说明OUT参数将参数值传回给调用者。

mysql> select @num;

+------+

| @num |

+------+

|  100 |

+------+

1 row in set (0.00 sec)


然后

mysql> drop procedure p_in ;

Query OK, 0 rows affected (0.00 sec)

mysql> drop procedure p_inout ;

Query OK, 0 rows affected (0.00 sec)

mysql> drop procedure p_out ;

Query OK, 0 rows affected (0.00 sec)



那么总结如下:
IN参数:
仅需要将数据传入存储过程,并不需要返回计算后的该值。
OUT参数:
不接受外部传入的数据,仅返回计算之后的值。
INOUT参数:
需要数据传入存储过程经过调用计算 后,再传出返回值。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值