本质上没区别。只是函数有如:只能返回一个变量的限制。而存储过程可以返回多个。而函数是可以嵌入在sql中使用的,可以在select中调用,而存储过程不行。执行的本质都一样。
函数限制比较多,比如不能用临时表,只能用表变量.还有一些函数都不可用等等.而存储过程的限制相对就比较少
1. 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。
2. 对于存储过程来说可以返回参数,而函数只能返回值或者表对象。
3. 存储过程一般是作为一个独立的部分来执行(EXEC执行),而函数可以作为查询语句的一个部分来调用(SELECT调用),由于函数可以返回一个表对象,因此它可以在查询语句中位于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在下次执行时就不用再编译了。
- 浏览: 55563 次
- 来自: 北京
最新评论
-
x10232:
3+3+4+4
impala学习总结 -
x10232:
一个房子里有椅子,椅子有腿和背,房子与椅子是什么关系,椅子与腿 ...
关联、组合、聚合、依赖关系比较
SQL中存储过程和函数的区别
- 博客分类:
- 数据库
相关推荐
原创sql存储过程函数范例,一是为了自己方便查找,今天到公司因为没有我保存的一些范例,一个简单的例子写了半个小时,如果有范例直接套几分钟肯定搞定,所以索性上传到CSDN上,何时何地都能找到我的范例了。...
适合sqlserver数据库初学者,实验四存储过程和函数实验
很清晰的说明了存储过程和函数的区别
常用SQL工具存储过程与函数.rar常用SQL工具存储过程与函数.rar
简单的学习例子 sqlserver 存储过程、函数的创建和使用 和 常用知识点
sql 存储过程常用函数及游标用法 这里包括 字符函数,数据库维护命令,所有游标的用法以及日期函数
笔者找到的功能最强大、操作最简单、使用最可靠的数据库解密工具,用于解密的SQL Server2000、2005等版本的存储过程、函数、触发器和视图。 执行连接到数据库后,左边直接列出数据库清单以及每个数据库内的存储过程...
SQL2000存储过程,视图,函数,触发解密
Oracle学习开发常用的SQL和存储过程学习(内含SQL面试题目和存储过程,函数面试题目,里面有丰富的SQL基本语法学习和SQL练习题以及存储过程非常适合新手和找工作的人群
PL-SQL_存储过程与函数.doc 介绍存储过程和函数,技术爱好者必看。
SQL Server 的扩展存储过程,其实就是一个普通的 Windows DLL,只不过按照某种规则实现了某些函数而已。本文介绍一下扩展存储过程,该动态库导出了三个函数: Init,work,Final,Init读文件,存储信息于内存,work简单的...
讲述Oracle和SQL Server的一些区别(函数和存储过程),比较实用
oracle pl/sql 存储过程和函数与触发器
SQL存储过程,视图,函数,触发器解密工具,本人测试可用。不知道是谁开发的。感谢作者,我拿来给大家分享。
在SQL存储过程中进行参数数组Array Parameter的处理函数。
T_SQL与存储过程数据分析
在VB6.0中调用SQL Server的存储过程.pdf
EJB3JPA调用原生SQL和函数存储过程[归类].pdf
解密SQL触发器、存储过程、函数,本人用过,可以用
NULL 博文链接:https://baobeituping.iteye.com/blog/906087