存储过程用SQL语句获得一个存储过程返回的表

Posted 多安分

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了存储过程用SQL语句获得一个存储过程返回的表相关的知识,希望对你有一定的参考价值。

定义一个存储过程如下:

create proc [dbo].[test1]
@id int
as
select 1 as id,‘abc‘ as name union all 
select @id as id,‘zzz‘ as name

 

返回两行数据.
现在想用SQL语句来调用这个存储过程,并把他返回的表放入变量中.可以如下做:

declare   @table   table(id   int,name varchar(50))--定义表变量来存放存储过程返回的内容
insert  into @table exec test1 2--将存储过程执行的结果放入表变量中
select *
from @table    --查看表变量中的结果

 

这么写的话,如果列很多,将会很麻烦

目前没有一个类似 as temp表的方法

select * from (exec test1 1) as temp

后续再找找看吧

以上是关于存储过程用SQL语句获得一个存储过程返回的表的主要内容,如果未能解决你的问题,请参考以下文章

如何获取存储过程以输出从 SQL*Plus 中的 select 语句返回的表?

oracle 存储过程执行动态SQL 返回结果给游标,外部程序获得dataset结果集。

Hibernate 调用存储过程 该语句没有返回结果集

我用sqlserver写好了一个存储过程 怎么样才能返回出一个搜索语句的结果集给c#

用存储过程好,还是在代码中写SQL语句好

sql存储过程有什么用