在MySQL中,存储过程支持IN、OUT和INOUT三种参数传递方式
-
IN参数:这是默认的参数传递方式。当你将一个参数声明为IN时,表示该参数的值会从调用者传递到存储过程内部,但在存储过程内部不能修改其值。
-
OUT参数:当你将一个参数声明为OUT时,表示该参数的值会从存储过程返回到调用者。在存储过程内部可以修改该参数的值,并将其作为输出结果返回给调用者。
-
INOUT参数:当你将一个参数声明为INOUT时,表示该参数的值既可以从调用者传递到存储过程内部,也可以从存储过程返回到调用者。在存储过程内部可以修改该参数的值,并将其作为输出结果返回给调用者。
下面是一个简单的示例,展示了如何在MySQL存储过程中使用INOUT参数:
DELIMITER // CREATE PROCEDURE test_inout(INOUT a INT) BEGIN SET a = a * 2; END // DELIMITER ;
在上述示例中,我们创建了一个名为test_inout
的存储过程,它接受一个名为a
的INOUT参数。在存储过程内部,我们将a
的值乘以2,然后将结果返回给调用者。
要调用此存储过程并传递一个INOUT参数,可以使用以下语句:
SET @input = 5; CALL test_inout(@input); SELECT @input;
在上述示例中,我们首先设置了一个名为@input
的变量,并将其值设置为5。然后,我们调用test_inout
存储过程,并将@input
作为INOUT参数传递。最后,我们查询@input
的值,可以看到它已经被存储过程修改为原始值的两倍(即10)。