Sqlserver存储过程返回表,如何实现?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Sqlserver存储过程返回表,如何实现?相关的知识,希望对你有一定的参考价值。
Create Procedure CS_GR_AlloDays
@LeaveTypeId int,
@UserName nvarchar(50)
As
declare @strWhere varchar(100);--查询条件,模糊查询
declare @strcmd varchar(1500);
if(@UserName is null) --全部查询
set @strWhere=''
else
set @strWhere='where E.LoginName like %'+@UserName+'%'
set @strcmd=' select F.LeaveItem,E.*,F.DefaultDay,E.DaysUsed from('+
'select LoginName,DaysUsed'+
'from Right_Users A'+
'Inner join('+
' select proposerID ,sum(LeaveDay) as DaysUsed from LM_Leave '+
' where LeaveTypeId='+@LeaveTypeId+' and LeaveStatusID=0 group by proposerID'+
') B on B.ProposerId=A.UsersID )E'+
'left join LM_LeaveType F on F.LeaveTypeId='+@LeaveTypeId+@strWhere
exec(@strcmd)
--------------
传参数执行以后 返回这个:
USE [AMK_GRP_Dev]
GO
DECLARE @return_value int
EXEC @return_value = [dbo].[CS_GR_AlloDays]
@LeaveTypeId = 1
SELECT 'Return Value' = @return_value
GO
---------
返回 'Return Value'=null.
请问如何返回我想要的表?
create proc p_abc @i int
as
--中间有个非常复杂的计算
select * from #tmp where fid=@i
go
create proc p_test @i int
as
set nocount on
create table #temp(.....)
insert into #temp
exec p_abc @i --执行这个语句后返回一个table,把这个返回结果插入到临时表
go 参考技术A 有一个问题,我想问一下
我看你的存储过程的语句,感觉没有必要用sql拼接的方式来执行。完全可以直接用sql语句来写,然后传递参数实现
如果你要返回一张表,那么你的sql语句只要是一个select语句就行了。只是在调用的时候用IDataReader来读取就可以了。本回答被提问者采纳
以上是关于Sqlserver存储过程返回表,如何实现?的主要内容,如果未能解决你的问题,请参考以下文章
如何返回sqlserver 中存储过程的select的结果集
如何在sqlserver的存储过程中,实现根据输入的参数获取数据表中的对应列的数据
PHP如何调用SQLServer2012的存储过程并获取返回结果集及出参?