从表值项

时间:2015-11-25 10:43:16

标签: sql sql-server database stored-procedures table-valued-parameters

我有一个名为“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

1 个答案:

答案 0 :(得分:0)

不可能从您创建的表值函数中执行存储过程,但是您可以将存储过程更改为表值函数。