当前位置:首页>开发>正文

mysql的存储过程和函数的区别 mysql 存储过程和函数的区别

2023-07-06 21:28:34 互联网 未知 开发

 mysql的存储过程和函数的区别 mysql 存储过程和函数的区别

mysql的存储过程和函数的区别

1)一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。存储过程,功能强大,可以执行包括修改表等一系列数据库操作;用户定义函数不能用于执行一组修改全局数据库状态的操作。

2)对于存储过程来说可以返回参数,如记录集,而函数只能返回值或者表对象。函数只能返回一个变量;而存储过程可以返回多个。存储过程的参数可以有IN,OUT,INOUT三种类型,而函数只能有IN类~~存储过程声明时不需要返回类型,而函数声明时需要描述返回类型,且函数体中必须包含一个有效的RETURN语句。

3)存储过程,可以使用非确定函数,不允许在用户定义函数主体中内置非确定函数。

mysql 存储过程和函数的区别

1、函数必须指定返回值,且参数默认为IN类型。

2、存储过程没返回值,参数可以是 IN,OUT,IN OUT类型,有的人可能会理解成OUT 也算是返回值。
3、调用方式:函数 select my_fun() 过程 call my_pro( )
4、DEMO
DELIMITER $$
DROP FUNCTION IF EXISTS my_fun$$
CREATE
    FUNCTION my_fun(a INT(2),b INT(2))
    RETURNS INT(4)
    BEGIN
DECLARE sum_ INT(2) DEFAULT 0
SET sum_ = a   b
RETURN sum_
    END$$
DELIMITER DELIMITER $$
DROP PROCEDURE IF EXISTS my_pro$$
CREATE
    PROCEDURE my_pro(IN a INT(2),IN b INT(2) ,OUT c INT(2))
    BEGIN
SET c = a   b
    END$$
DELIMITER 5、调用
mysql> call my_pro(1,2,@c)
Query OK, 0 rows affected (0.00 sec)

mysql> select @c
------
| @c   |
------
|    3 |
------
1 row in set (0.00 sec)

mysql> select my_fun(1,2)
-------------
| my_fun(1,2) |
-------------
|           3 |
-------------
1 row in set (0.00 sec)

Mysql存储过程和函数的区别

两个区别如下:
1、函数必须指定返回值,且参数默认为IN类型。

2、存储过程没返回值,参数可以是 IN,OUT,IN OUT类型,有的人可能会理解成OUT 也算是返回值。
3、调用方式:函数 select my_fun() 过程 call my_pro( )
举例:
函数:
DELIMITER $$
DROP FUNCTION IF EXISTS my_fun$$
CREATE
    FUNCTION my_fun(a INT(2),b INT(2))
    RETURNS INT(4)
    BEGIN
    DECLARE sum_ INT(2) DEFAULT 0
    SET sum_ = a   b
    RETURN sum_
    END$$
DELIMITER 存储过程:
DELIMITER $$
DROP PROCEDURE IF EXISTS my_pro$$
CREATE
    PROCEDURE my_pro(IN a INT(2),IN b INT(2) ,OUT c INT(2))
    BEGIN
    SET c = a   b
    END$$
DELIMITER 函数调用方式:
mysql> select my_fun(1,2)
-------------
| my_fun(1,2) |
-------------
|           3 |
-------------
1 row in set (0.00 sec)存储过程调用方式:
mysql> call my_pro(1,2,@c)
Query OK, 0 rows affected (0.00 sec)

mysql> select @c
------
| @c   |
------
|    3 |
------
1 row in set (0.00 sec)