Mysql:函数与存储过程对比
业务场景中我们在做数据处理时,有时为了代码复用性,性能问题等,在数据库处理数据时会根据实际情况写合适的函数和存储过程来供服务层调用,简要说下两者的限制情况:函数只能通过return语句返回单个值或者表对象。而存储过程不允许执行return,但是通过out参数返回多个值。 函数是可以嵌入在sql中使用的,可以在select中调用,而存储过程不行。函数限制比较多,如不能用临时表,只能用表变量等,而存储过程的限制相对就比较少。
一、为什么要用他们?
存储过程和函数是事先经过编译并存储在数据库中的一段 SQL 语句的合集,调用存储过程和函数可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。
二、存储过程&自定义函数
存储过程可以看成是对一系列 SQL 操作的批处理。是SQL语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可由应用程序通过一个调用执行(Call 存储过程名称(params)),而且允许用户声明变量、有条件执行以及其它强大的编程功能。存储过程可包含程序流、逻辑以及对数据库的查询。它们可以接受参数、输出参数、返回单个或多个结果集以及返回值。命令行中创建存储过程需要自定义分隔符,因为命令行是以 ; 为结束符,而存储过程中也包含了分号,因此会错误把这部分分号当成是结束符,造成语法错误。
自定义函数:是由一个或多个 SQL 语句组成的子程序,可用于封装代码以便重新使用。 函数限制比较多,针对性较强,只能用表变量等
特点:
- 代码封装,保证了一定的安全性;
- 代码复用;
- 由于是预先编译,因此具有很高的性能。
三、相同点
- 存储过程和函数都是为了可重复的执行操作数据库的 SQL 语句的集合。
- 存储过程和函数都是一次编译后缓存起来,下次使用就直接命中已经编译好的 sql 语句,减少网络交互提高了效率。
四、不同点
1、使用限制不同
- 函数限制比较多,比如不能用临时表,只能用表变量,一些函数都不可用等,而存储过程的限制相对就比较少。
- 存储过程:单个存储过程中可以执行一系列 SQL 语句以及引用其它存储过程,这可以简化一系列复杂的语句。
- 函数:自定义函数诸多限制,可以直接引用返回值,用表变量返回记录集,但是不能用于执行一组修改全局数据库状态的操作。
- 存储过程,可以使用非确定性函数,函数主体中不允许内置非确定性函数。(给同样的参数,确定性函数执行多少次都是一样的结果,非确定性函数执行多次结果可能不一样)
2、参数不同
- 函数的参数只能是 IN 类型,存储过程的参数可以是IN OUT INOUT三种类型。
3、返回结果不同
- 存储过程:存储过程可以返回参数,如记录集,函数只能返回值或者表对象,而且声明时不需要返回类型。
- 函数需要描述返回类型,函数中必须包含return语句,返回值有且只能有一个
- call 存储过程(procedure):可以有0个返回,也可以有多个(out参数)返回,适合做批量插入、批量更新
- select 函数(function):有且仅有1 个返回,适合做处理数据后返回一个结果(return 返回类型)
- 函数返回单个值或者表对象,而存储过程没有返回值,但是可以通过OUT参数返回多个值
4、执行方式不同
- 存储过程一般是作为一个独立的部分来执行( EXECUTE 语句执行,call语句调用)
- 函数可以作为查询语句的一个部分来调用(在sql语句中select调用),由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。
5、语法场景不同
- 标识符不同,函数的标识符是 function,存储过程是 procedure。
- 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强
- 存储函数使用 select 调用,存储过程需要使用 call 调用。
- SQL语句中不可用存储过程,而可以使用函数。
还没有评论,来说两句吧...