MySQL存储过程的参数(转)

MySQL存储过程的参数用在存储过程的定义,共有三种参数类型,IN,OUT,INOUT,形式如:

CREATE PROCEDURE([[IN |OUT |INOUT ] 参数名 数据类形...])

IN 输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值

OUT 输出参数:该值可在存储过程内部被改变,并可返回

INOUT 输入输出参数:调用时指定,并且可被改变和返回

 

Ⅰ. IN参数例子

创建:  

1. mysql > DELIMITER //  

2. mysql > CREATE PROCEDURE demo_in_parameter(IN p_in int)  

3.      -> BEGIN   

4.      -> SELECT p_in; /*查询输入参数*/  

5.      -> SET p_in=2; /*修改*/  

6.      -> SELECT p_in; /*查看修改后的值*/  

7.      -> END;   

8.      -> //  

9. mysql > DELIMITER ; 


执行结果:

1. mysql > SET @p_in=1;  

2. mysql > CALL demo_in_parameter(@p_in);  

3. +------+  

4. | p_in |  

5. +------+  

6. |   1  |   

7. +------+  

8.  

9. +------+  

10. | p_in |  

11. +------+  

12. |   2  |   

13. +------+  

14.  

15. mysql> SELECT @p_in;  

16. +-------+  

17. | @p_in |  

18. +-------+  

19. |  1    |  

20. +-------+  


以上可以看出,p_in虽然在存储过程中被修改,但并不影响@p_id的值

 

Ⅱ.OUT参数例子

创建:

1. mysql > DELIMITER //  

2. mysql > CREATE PROCEDURE demo_out_parameter(OUT p_out int)  

3.      -> BEGIN 

4.      -> SELECT p_out;/*查看输出参数*/  

5.      -> SET p_out=2;/*修改参数值*/  

6.      -> SELECT p_out;/*看看有否变化*/  

7.      -> END;  

8.      -> //  

9. mysql > DELIMITER ; 


执行结果:

1. mysql > SET @p_out=1;  

2. mysql > CALL sp_demo_out_parameter(@p_out);  

3. +-------+  

4. | p_out |   

5. +-------+  

6. | NULL  |   

7. +-------+  

8. /*未被定义,返回NULL*/  

9. +-------+  

10. | p_out |  

11. +-------+  

12. |   2   |   

13. +-------+  

14.  

15. mysql> SELECT @p_out;  

16. +-------+  

17. | p_out |  

18. +-------+  

19. |   2   |  

20. +-------+  


Ⅲ. INOUT参数例子

创建:

1. mysql > DELIMITER //   

2. mysql > CREATE PROCEDURE demo_inout_parameter(INOUT p_inout int)   

3.      -> BEGIN 

4.      -> SELECT p_inout;  

5.      -> SET p_inout=2;  

6.      -> SELECT p_inout;   

7.      -> END;  

8.      -> //   

9. mysql > DELIMITER ; 

 

 

执行结果:

1. mysql > SET @p_inout=1;  

2. mysql > CALL demo_inout_parameter(@p_inout) ;  

3. +---------+  

4. | p_inout |  

5. +---------+  

6. |    1    |  

7. +---------+  

8.  

9. +---------+  

10. | p_inout |   

11. +---------+  

12. |    2    |  

13. +---------+  

14.  

15. mysql > SELECT @p_inout;  

16. +----------+  

17. | @p_inout |   

18. +----------+  

19. |    2     |  

20. +----------+

posted on 2012-11-30 14:09  davidkam  阅读(620)  评论(0编辑  收藏  举报