存储过程与自定义函数的区别 总结

上一篇 / 下一篇  2011-04-09 10:47:08 / 天气: 阴雨 / 心情: 平静 / 精华(2) / 置顶(2) / 不允许评论 / 个人分类:数据库

一 存储过程与函数的区别

1 存储过程
定义:
存储过程(Stored Procedure )是一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行
它。
优 点:
A 存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
B 当对数据库进行复杂操作时(如对多个表进行Update、Insert、Query、Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。存储过程可以
从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句.
C 安全性高,可设定只有某用户才具有对指定存储过程的使用权。
D 存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值,可以向程序返回错误原因。  
2 合理使用存储过程与函数
存储过程: 参数可以有三种模式(IN、OUT、IN OUT),可返回多个参数值.可在过程中调用另一个存储过程.
函数: 函数只有一种(IN),因为使用函数的目的是传入0或多个参数,它只有一条RETURN语句,只能返回单一的值,也可用Out来返回值.可在SQL语句(DML或SELECT)中调用.

   区别:
名称      有返回值?         可以单独执行?            能嵌入SQL语句中?          参数类型             返回值类型    
存储过程    可以没有          可以                   不可以                      IN   OUT  IN OUT       可以返回参数(一个或                                 
                                                                                                       多个参数值)结果集、返                                
                                                                                                        回错误原因
自定义函数  必须有且只有一个 必须通过execute执行    可以 且位于FROM关键字的后面   只有IN               单一值或者一个表对象 

TAG:

 

评分:0

我来说两句

日历

« 2024-05-10  
   1234
567891011
12131415161718
19202122232425
262728293031 

数据统计

  • 访问量: 20962
  • 日志数: 26
  • 建立时间: 2011-03-26
  • 更新时间: 2012-12-06

RSS订阅

Open Toolbar