jiangfeng的专栏

    得了神经病的精神病!!!

存储过程中调用另一个存储过程的结果集

在一个存储过程中把另一个存储过程当一个表来使用,在sql server中不支持直接从from后接存储过程。这个时候我们可以利用临时表来实现。

举例:

 SELECT ID, RoleId, RoleType into #TempPurviewTableContainer  FROM SystemPurview  WHERE 1=0
 
 INSERT #TempPurviewTableContainer exec PManage_GetPurview @Type,@Id
 
 select * from #TempPurviewTableContainer

需要注意的是,这种方法不能嵌套。例如:

  procedure   a  
  begin  
      ...  
      insert   #table   exec   b  
  end  
   
  procedure   b  
  begin  
      ...  
      insert   #table    exec   c  
      select   *   from   #table     
  end  
   
  procedure   c  
  begin  
      ...  
      select   *   from   sometable   
  end  

这里a调b的结果集,而b中也有这样的应用b调了c的结果集,这是不允许的,会报“INSERT EXEC 语句不能嵌套”错误。在实际应用中要避免这类应用的发生。如果谁有好的解决方法,请留言!

阅读更多
个人分类: 数据库
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

存储过程中调用另一个存储过程的结果集

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭