首页 > 数据库技术 > 详细

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

时间:2016-01-08 20:22:52      阅读:203      评论:0      收藏:0      [点我收藏+]

定义一个存储过程如下:

技术分享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 --查看表变量中的结果

-------------------------------------------------------------------------------------------------

使用心得:

原先准备直接通过存储过程的output变量返回table,发现失败,

换成函数可以返回,但函数内部禁用了很多系统函数,例如exec,无法实现复杂的sql,

最终,通过存储过程直接

“insert into @table exec test1 2--将存储过程执行的结果放入表变量中”

的方式,将存储过程的返回值放入临时表变量,间接实现返回表变量

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

原文:http://www.cnblogs.com/jx270/p/5114349.html

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