Code Bye

关于存储过程的

 create procedure p
(in v_a int ,in v_b int ,out v_c int)
begin
if v_a>v_b then
v_a into v_c;
else
v_b into v_c;
end if;
end;
//
问一下这个存储过程为什么错了,没有一点头绪,就是取出最大值,另外假如一个参数既做输出又做输入该怎么定义呢?
create procedure p
(in v_a int ,in v_b int ,out v_c int ,in out v_d)
这样可以吗?
解决方案

5

先尝试一下分析MYSQL给出的错误提示,然后假如是语法错误是参考一下MYSQL的官方免费手册中的例子。

35

  if v_a>v_b then
v_a into v_c;
else
v_b into v_c;
end if;
— 》》
if v_a>v_b then
select     v_a into v_c;
else
select  v_b into v_c;
end if;

CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明关于存储过程的