mysql 存储过程和函数的区别

作者&投稿:葛莫 (若有异议请与网页底部的电邮联系)
mysql的存储过程和函数的区别~

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

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

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

1、函数必须指定返回值,且参数默认为IN类型。
2、存储过程没返回值,参数可以是 IN,OUT,IN OUT类型,有的人可能会理解成OUT 也算是返回值。
3、调用方式:函数 select my_fun() ;过程 call my_pro( ) ;
4、DEMO

1
2
3
4
5
6
7
8
9
10
11

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 ;



1
2
3
4
5
6
7
8

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 存储过程和函数的区别

1、

存储过程实现的功能要复杂一点,函数实现的功能针对性比较强。

存储过程,功能强大,可以执行包括修改表等一系列数据库操作;

用户定义函数不能用于执行一组修改全局数据库状态的操作。


2、

对于存储过程来说可以返回参数,如记录集,函数只能返回值或者表对象。

函数只能返回一个变量;而存储过程可以返回多个;

存储过程的参数可以有IN,OUT,INOUT三种类型,而函数只能有IN类;

存储过程声明时不需要返回类型,而函数声明时需要描述返回类型,且函数体中必须包含一个有效的RETURN语句。



3、

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




4、

存储过程一般是作为一个独立的部分来执行( EXECUTE 语句执行),而函数可以作为查询语句的一个部分来调用(SELECT调用)。

由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。 SQL语句中不可用存储过程,而可以使用函数。



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)


函数可以直接写在sql 语句中,存储过程需要单独call。


腾冲县13865627255: Mysql存储过程和函数的区别 -
察子康艾: 两个区别如下: 1、函数必须指定返回值,且参数默认为IN类型.2、存储过程没返回值,参数可以是 IN,OUT,IN OUT类型,有的人可能会理解成OUT 也算是返回值. 3、调用方式:函数 select my_fun() ;过程 call my_pro( ) ; 举例: 函数...

腾冲县13865627255: mysql 存储过程和函数的区别 -
察子康艾: 1、函数必须指定返回值,且参数默认为IN类型.2、存储过程没返回值,参数可以是 IN,OUT,IN OUT类型,有的人可能会理解成OUT 也算是返回值. 3、调用方式:函数 select my_fun() ;过程 call my_pro( ) ; 4、DEMO DELIMITER $$ DROP...

腾冲县13865627255: mysql的存储过程和函数的区别 -
察子康艾: 1)一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强.存储过程,功能强大,可以执行包括修改表等一系列数据库操作;用户定义函数不能用于执行一组修改全局数据库状态的操作. 2)对于存储过程来说可以返回参数,如记录集,而函数只能返回值或者表对象.函数只能返回一个变量;而存储过程可以返回多个.存储过程的参数可以有IN,OUT,INOUT三种类型,而函数只能有IN类~~存储过程声明时不需要返回类型,而函数声明时需要描述返回类型,且函数体中必须包含一个有效的RETURN语句. 3)存储过程,可以使用非确定函数,不允许在用户定义函数主体中内置非确定函数.

腾冲县13865627255: mysql 函数 与 存储过程 有什么区别? 如果不好回答 可以只说说 优缺点 -
察子康艾: 1.存储过程可以传入、传出变量,函数只有传入2.调用方式不同··存储过程是CALL myfun(); 函数则是SELECT myfun(); 楼下继续补充~~~

腾冲县13865627255: mysql的 储存过程 和 储存函数 有什么区别 -
察子康艾: 函数是返回一个值,如0、1之类,需要在里面有return值;过程是返回结果集,如select * from tableA;存储过程里面可以调用函数.

腾冲县13865627255: 在数据库应用中,函数与存储过程有哪些异同点 -
察子康艾: 存储过程是预编译的,执行效率比函数高. 存储过程可以不返回任何值,也可以返回多个输出变量,但函数有且必须返回一个值. 存储过程必须单独执行,而函数可以嵌入表达式中,使用更灵活. 存储过程主要是用于对逻辑处理的应用或解决,函数主要是一种功能应用或解决.

腾冲县13865627255: 数据库中存储过程和函数的区别 -
察子康艾: 函数分两种,表值函数跟标量函数 表值函数最后要返回一个表变量,而标量函数最后要返回一个标量值 存储过程即一组批处理,可以返回或不返回值,仅仅是执行其内部的全部语句 函数可以与一般sql语句一同编写,而存储过程不可以,需要单独执行

腾冲县13865627255: SQL中存储过程和函数的区别 -
察子康艾: 本质上没区别.只是函数有如:只能返回一个变量的限制.而存储过程可以返回多个.而函数是可以嵌入在sql中使用的,可以在select中调用,而存储过程不行.执行的本质都一样. 函数限制比较多,比如不能用临时表,只能用表变量.还有一...

腾冲县13865627255: 存储过程和函数有什么区别 -
察子康艾: 1. 返回值的区别,函数有1个返回值,而存储过程是通过参数返回的,可以有多个或者没有 2.调用的区别,函数可以在查询语句中直接调用,而存储过程必须单独调用. 函数一般情况下是用来计算并返回一个计算结果而存储过程一般是用来完成特定的数据操作(比如修改、插入数据库表或执行某些DDL语句等等)

腾冲县13865627255: 函数和存储过程的区别 -
察子康艾: 函数一般是传入一个标量参数,也就是某个具体的值,进行适当加工后返回合适的结果.函数不允许进行数据库操作,比如在函数里是不允许执行SQL语句的.而存储过程也可以接受参数,不过它一般是依据传入的参数对数据进行不同的处理,这时一般是执行SQL语句操作数据.

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网