我在 mysql 中有一个过程,它有 4 个参数作为输入,3 个参数作为 OUTPUT,并且 OUTPUT 的一个参数不返回任何内容(null)。
DELIMITER $$
drop procedure if exists `cierreMes`$$
create procedure cierreMes (in tarjeta varchar(100),in bancoBus varchar(100),in mes int,in anyo int, out total int, out nulas int, out erroneas int)
begin
declare stockActual int default 0;
declare cantidad int;
/*declare xcantidad,xnulas,xerroneas int;*/
declare entrada, salida int default 0;
declare total int default 0;
select stock
into stockActual
from almacen
where idProducto =
(select idProducto from productos where productos.banco = bancoBus and productos.plastico = tarjeta);
call entradasSalidas(tarjeta,bancoBus,mes,anyo,@ent,@sal);
set entrada = @ent;
set salida = @sal;
call obtenerMovimientosMes(tarjeta,bancoBus,mes,anyo,@cant,@nul,@err);
set cantidad = @cant;
set nulas = @nul;
set erroneas = @err;
set total =(stockActual + entrada) - (salida + cantidad);
select total;
end$$
DELIMITER ;
call cierreMes('4B MC','SANTANDER',3,2013, @total, @nulas, @erroneas);
select @total, @nulas, @erroneas;
当我“调用”@nulas 和@erroneas 时返回一个值,但@total 什么也没有。
选择总计,它的工作正常。但没有返回值,在此选择中:选择@total,@nulas,@erroneas;@total 为空。