如何将 exec 结果赋给 sql 变量?

如何将 exec 调用的结果分配给 SQL 中的变量?我有一个名为 up_GetBusinessDay的存储过程,它返回一个日期。

你能这样做吗:

exec @PreviousBusinessDay = dbo.up_GetBusinessDay @Date, -1
372922 次浏览

文件(假设您使用 SQL-Server) :

USE AdventureWorks;
GO
DECLARE @returnstatus nvarchar(15);
SET @returnstatus = NULL;
EXEC @returnstatus = dbo.ufnGetSalesOrderStatusText @Status = 2;
PRINT @returnstatus;
GO

所以是的,应该是这样的。

我总是使用返回值来返回错误状态。如果需要传回一个值,我会使用一个输出参数。

带有 OUTPUT 参数的 sample 存储过程:

CREATE PROCEDURE YourStoredProcedure
(
@Param1    int
,@Param2    varchar(5)
,@Param3    datetime OUTPUT
)
AS
IF ISNULL(@Param1,0)>5
BEGIN
SET @Param3=GETDATE()
END
ELSE
BEGIN
SET @Param3='1/1/2010'
END
RETURN 0
GO

使用 OUTPUT 参数调用存储过程:

DECLARE @OutputParameter  datetime
,@ReturnValue      int


EXEC @ReturnValue=YourStoredProcedure 1,null, @OutputParameter OUTPUT
PRINT @ReturnValue
PRINT CONVERT(char(23),@OutputParameter ,121)

产出:

0
2010-01-01 00:00:00.000

如果你想简单地返回一个整数,这个方法可以奏效:

DECLARE @ResultForPos INT
EXEC @ResultForPos = storedprocedureName 'InputParameter'
SELECT @ResultForPos
declare @EventId int


CREATE TABLE #EventId (EventId int)


insert into #EventId exec rptInputEventId


set @EventId = (select * from #EventId)


drop table #EventId

我也有同样的问题。虽然这里有很好的答案,但我决定创建一个表值函数。使用表(或标量)值函数时,不必更改存储的 proc。我只是从表值函数中做了一个选择。注意,参数(MyParameter 是可选的)。

CREATE FUNCTION [dbo].[MyDateFunction]
(@MyParameter varchar(max))
RETURNS TABLE
AS
RETURN
(
--- Query your table or view or whatever and select the results.
SELECT DateValue FROM MyTable WHERE ID = @MyParameter;
)

为了赋值给你的变量,你可以简单地这样做:

Declare @MyDate datetime;
SET @MyDate = (SELECT DateValue FROM MyDateFunction(@MyParameter));

也可以使用标量值函数:

CREATE FUNCTION TestDateFunction()
RETURNS datetime
BEGIN
RETURN (SELECT GetDate());
END

然后你就可以

Declare @MyDate datetime;
SET @MyDate = (Select dbo.TestDateFunction());
SELECT @MyDate;

下面是动态查询的解决方案。

例如,如果有更多带不同后缀的表:

dbo.SOMETHINGTABLE_ONE, dbo.SOMETHINGTABLE_TWO

密码:

DECLARE @INDEX AS NVARCHAR(20)
DECLARE @CheckVALUE AS NVARCHAR(max) = 'SELECT COUNT(SOMETHING) FROM
dbo.SOMETHINGTABLE_'+@INDEX+''
DECLARE @tempTable Table (TempVALUE int)
DECLARE @RESULTVAL INT


INSERT INTO @tempTable
EXEC sp_executesql @CheckVALUE


SET @RESULTVAL = (SELECT * FROM @tempTable)


DELETE @tempTable


SELECT @RESULTVAL

您可以为此使用表变量

密码:

DECLARE @PreviousBusinessDay DATETIME
DECLARE @Temp TABLE(BusinessDay DATETIME)
INSERT INTO @Temp EXEC dbo.up_GetBusinessDay @Date, -1
SET @PreviousBusinessDay = (SELECT * FROM @Temp)
SELECT @PreviousBusinessDay

Https://www.sqlservertutorial.net/sql-server-user-defined-functions/sql-server-table-variables/