SQL函数和存储过程的区别

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL函数和存储过程的区别相关的知识,希望对你有一定的参考价值。

不同点:
1、标识符不同。函数的标识符为FUNCTION,过程为:PROCEDURE。
2、函数中有返回值,且必须返回,而过程可以没有返回值。
3、过程无返回值类型,不能将结果直接赋值给变量;函数有返回值类型,调用时,除在select中,必须将返回值赋给变量。
4、函数可以在select语句中直接使用实现对字段进行计算,而存储过程不能,
例如:假设已有函数fun_getAVG() 返回number类型绝对值。
那么select fun_getAVG(col_a) from table 这样是可以的。
5、函数一般处理简单的逻辑方便,存储过程一般处理复杂的逻辑,

相同点:
1、二者都可以有输出
2、二者写法逻辑上很相似
参考技术A 函数有返回值。存储过程没有返回值。 参考技术B 楼上不对吧,Oracle的存储过程可是有返回值的

面试问题 - SQL 中存储过程与函数的区别

SQL 中的存储过程与函数没有本质上的区别

函数 -> 只能返回一个变量. 函数可以嵌入到sql中使用, 可以在select 中调用, 而存储过程不行.  但函数也有着更多的限制,比如不能使用临时表

存储过程 -> 可以返回多个变量.

存储过程的定义如下: 

存储过程可以使得对数据库的管理、以及显示关于数据库及其用户信息的工作容易得多。存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。存储过程可以包含 程序流,逻辑以及对数据库的查询. 它们可以接受参数,输出参数,返回单个或多个结果集以及返回值.

可以出于任何使用SQL语句的目的来使用存储过程,特点如下:

1. 可以在单个存储过程中执行一系列语句

2. 可以从自己的存储过程内引用其他存储过程,这可以简化一系列复杂语句.

3. 存储过程在创建时即在服务器上进行编译,所以执行起来比单个SQL语句快.

 

用户定义函数

与任何函数一样,用户定义函数是可返回值的例程.根据所返回值的类型,每个用户定义函数可以分3个类型:

1、返回可更新数据表的函数 
如果用户定义函数包含单个 SELECT 语句且该语句可更新,则该函数返回的表格格式结果也可以更新。
2、返回不可更新数据表的函数 
如果用户定义函数包含不止一个 SELECT 语句,或包含一个不可更新的 SELECT 语句,则该函数返回的表格格式结果也不可更新。
3、返回标量值的函数 
用户定义函数可以返回标量值。

 

两者区别

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

   2.对于存储过程来说可以返回参数,而函数只能返回值或者表对象。

   3.存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。

   4.当存储过程和函数被执行的时候,SQL Manager会到procedure cache中去取相应的查询语句,如果在procedure cache里没有相应的查询语句,SQL Manager就会对存储过程和函数进行编译。

Procedure cache中保存的是执行计划 (execution plan) ,当编译好之后就执行procedure cache中的execution plan,之后SQL SERVER会根据每个execution plan的实际情况来考虑是否要在cache中保存这个plan,评判的标准一个是这个execution plan可能被使用的频率;其次是生成这个plan的代价,也就是编译的耗时。保存在cache中的plan在下次执行时就不用再编译了。

 






以上是关于SQL函数和存储过程的区别的主要内容,如果未能解决你的问题,请参考以下文章

SQL中存储过程和函数的区别

面试问题 - SQL 中存储过程与函数的区别

SQL server基础SQL存储过程和函数的区别

SQL中存储过程和函数的区别

ORACLE存储过程里可以声明过程和函数吗

mysql 与oracle中的存储过程及函数有啥区别,尽可能详细哦