我有一个名为“GetSPTst”的存储过程,我从表值函数调用它。在这个函数中我返回一个表,以下是我的SQL代码。我收到错误“
Msg 443,Level 16,State 14,Procedure TstFunction第15行。无效 在函数中使用副作用运算符'INSERT EXEC'。“
你能帮忙吗?
IF EXISTS (SELECT *
FROM sys.objects
WHERE object_id = OBJECT_ID(N'[dbo].[TstFunction]
AND type IN ( N'FN', N'IF', N'TF', N'FS', N'FT' ))
DROP FUNCTION [dbo].[TstFunction]
GO
CREATE FUNCTION [dbo].[TstFunction]( @AsAtDate datetime, @DateFrom datetime, @DateTo datetime, @Ledger char(1), @CodeFrom varchar(6),
@CodeTo varchar(6), @CurrencyFrom char(3), @CurrencyTo char(3))
RETURNS @FunctionResultTableVariable TABLE (Currency char(3), Code varchar(6), BalOutst int)
AS
BEGIN
insert @FunctionResultTableVariable
EXECUTE [dbo].[GetSPTst]
@AsAtDate
,@DateFrom
,@DateTo
,@Ledger
,@CodeFrom
,@CodeTo
,@CurrencyFrom
,@CurrencyTo;
return;
END
GO
答案 0 :(得分:0)
不可能从您创建的表值函数中执行存储过程,但是您可以将存储过程更改为表值函数。