转载 sql 存储过程与函数区别

SQL
Server用户自定义函数和仓储过程有像样的效能,都足以创设捆绑SQL语句,存储在server中供之后使用。那样能够极大地升高工作效能,通过以下的种种做法得以减掉编程所需的流年:

  •   重复使用编程代码,收缩编程开发时间。
  •   
    隐藏SQL细节,把SQL繁琐的做事留给数据库开发人士,而先后开发员则集中处理高级编程语言。
  •   
    维修集中化,可以在八个地点做作业上的逻辑修改,然后让这一个改动自动应用到具有相关程序中。

  乍看之下,用户自定义函数和仓储进程的效果就像一摸一样。可是,其实那两者之间还有一些就算微小不过很首要的不一致:

  •   
    存储进程是使用EXEC命令独立调用的,而用户自定义函数是在另多少个SQL语句中调用的。
  •   
    存储程序是允许用户和程序去采取存储进程,而不是同意其存取表格,那样可以进步程序安全性。与标准的SQL
    Server相比较,存储程序限制用户行动权限方面越来越细化。例如,借使您有3个货存表格,每趟卖出一个商品收银员都要对表格进行翻新三次(从货存中把该商品减去一件)。你可以给收银员设置权限,允许其使用decrement_item存储进度,而不是同意她们有专断修改或村表格的权力。
  •   函数必须始终重回3个值(一个标量值或一个表格)。而存储进度可以回到1个标量值、一个表值或无需重回值。

    
用户自定义函数是有重临值的经过,表格重回值是要经过表变量来处理回来的历程。

    

     存储进度:

      它们还是能参数、输出参数、重返单个或多个结果集以及再次回到值

            壹 、能够在单个存储进度中实施一各个 SQL 语句。
           
二 、可以从友好的存储进度内引用其余存储进度,那可以简化一多级复杂语句。

            ③ 、存储进度在创立时即在服务器上举办编译,所以举行起来比单个
SQL 语句快。

   

     用户自定义函数:

    
与其余函数一样,用户定义函数是可再次来到值的例程。依照所再次回到值的档次,每一种用户定义函数可分为以下多个项目:

            ① 、再次回到可更新数据表的函数:即便用户定义函数包罗单个 Select
语句且该语句可更新,则该函数重临的表格格式结果也可以立异。

            ② 、重返不可更新数据表的函数:如若用户定义函数包括不止三个Select 语句,或包括三个不足更新的 Select
语句,则该函数再次回到的表格格式结果也不得更新。

            三 、再次回到标量值的函数:用户定义函数可以回来标量值。

 

    

            存储进度
    
           1. 作用强大,限制少
           2. 不大概一向引用重回值
           3. 用select语句重回记录集

           自定义函数

           1. 居多限量,有成百上千语句不只怕利用,许多效能不可以落到实处
           2. 得以一贯引用重回值
           3. 用表变量再次来到记录集

原文:http://www.cnblogs.com/snowhumen/archive/2012/07/02/2573502.html

相关文章