首页 > 数据库技术 > 详细

sqlserver 只有函数和扩展存储过程才能从函数内部执行

时间:2015-08-27 12:46:53      阅读:1839      评论:0      收藏:0      [点我收藏+]

一个SQLServer的自定义函数中调用一个自定义的存储过程,执行此函数后发出如下提示:“只有函数和扩展存储过程才能从函数内部执行"。
 原因:函数只能使用简单的sql语句,逻辑控制语句,复杂一点的存储过程是不能调用的,在函数里也不能使用execute  sp_executesql  或者execute 。解决方法把函数改为存储过程,然后在另一个存储过程中象调用函数一样使用此存储过程就可以了。
 下面是一个存储过程调用另一个存储过程的实例,有参数传递的。
 --存储过程sp_B  
  create  proc  sp_B  
  @A  int  ,    
  @B  int  ,   
  @C  int  output   
  AS  
   
  set  @C  =  @A  +  @B  
  go   
   
  --存储过程p_A  
  create  proc  sp_A   
  @A  int  ,    
  @B  int   
  as   
  declare   @C  int   
  exec  sp_B  @A  ,  @B  ,  @C  output   
  print  @C   
  go   
  --测试
  exec  sp_A   3  ,  5  

sqlserver 只有函数和扩展存储过程才能从函数内部执行

原文:http://www.cnblogs.com/opps/p/4762811.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!