存储过程里调用另一个存储过程的值

本文介绍了三种在SQL中使用存储过程的方法:直接调用返回值、通过创建临时表存储结果以及利用动态SQL执行复杂查询。这些方法适用于不同的场景,如获取单一返回值、存储查询结果或执行更复杂的数据库操作。

第一种:

USE [WMS]
GO

DECLARE @return_value int

EXEC @return_value = [dbo].[Sys_GetSysNo]
  @NoCode = N'D001'

SELECT 'Return Value' = @return_value

GO
 

第二种:创建一个临时表

create proc GetUserName
as
begin
    select 'UserName'
end

Create table #tempTable (userName nvarchar(50))
insert into #tempTable(userName)
exec GetUserName

select #tempTable

--用完之后要把临时表清空
drop table #tempTable--需要注意的是,这种方法不能嵌套

第三种:

DECLARE @return_status INT
DECLARE @cmdText nvarchar(4000)--nvarchar 很重要这个地方
SET @cmdText='SELECT @return_status=COUNT(0) FROM '+@tableNameAdd+' WHERE '+@whereField +'='+''''+@Ops+'''';   
execute sp_executesql @cmdText,N'@return_status int out',@return_status out;
print @return_status

转载于:https://www.cnblogs.com/JuneZhang/archive/2010/11/23/1885667.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值