- -- 创建测试存储过程
-
- delimiter //
- create procedure p_in ( IN num int )
- begin
- select num;
- set num=100;
- select num;
- end;
- //
- 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 参数:
- -- 创建测试存储过程
-
- delimiter //
- create procedure p_out ( OUT num int )
- begin
- select num;
- set num=100;
- select num;
- end;
- //
-
- 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 参数:
- -- 创建测试存储过程
-
- delimiter //
- create procedure p_inout ( INOUT num int )
- begin
- select num;
- set num=100;
- select num;
- end;
- //
-
- 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参数:
需要数据传入存储过程经过调用计算 后,再传出返回值。