-2

我正在处理来自我没有创建的软件合作伙伴的查询。我正在尝试将它用作我可以插入到表中的函数,因为我不是 sql 专家,我在使用 sintax 时遇到了困难。

感谢您的建议,我正在取得进展,现在我被困在如何添加额外的选择以包含一些连接表,我已禁用该部分将其转换为评论。这实际上在没有最终选择的情况下有效,但我需要最终选择,有什么想法吗?

alter function Renetest

(
@companytest nvarchar(8),
@fiscalyeartest int
)

returns @PERIODBALANCE TABLE
    (
     [Company] NVARCHAR(8)
    ,[BookID] NVARCHAR(12)
    ,[BalanceAcct] NVARCHAR(200)
    ,[FiscalYear] INT
    ,[FiscalPeriod] INT
    ,[BalanceType] NVARCHAR(1)
        ,[SegValue1] NVARCHAR(50)
    ,[SegValue2] NVARCHAR(50)
       ,[FiscalYearSuffix] NVARCHAR(8)
    ,[FiscalCalendarID] NVARCHAR(12)
    )
    as
    begin


Declare @company nvarchar(8);
Declare @fiscalyear INT;
DECLARE @FiscalPeriod INT;
Set @company = 'epic03'
set @Fiscalyear =  '2013'
SET @FiscalPeriod=0;
DECLARE @MaxPeriod AS NVARCHAR(20);
SET @MaxPeriod=(
                SELECT
                    MAX([Erp].[GLBookPer].[FiscalPeriod])
                FROM
                    [Erp].[GLBookPer] WITH (NOLOCK)
                WHERE
                    [Erp].[GLBookPer].[Company] IN (@company)
                    AND [Erp].[GLBookPer].[FiscalYear]=@FiscalYear
               );


WHILE @FiscalPeriod<=(@MaxPeriod)
    BEGIN
        INSERT  INTO @PERIODBALANCE
                (
                 [Company]
                ,[BookID]
                ,[BalanceAcct]
                ,[FiscalYear]
                ,[FiscalPeriod]
                ,[BalanceType]
                ,[SegValue1]
                ,[SegValue2]
                ,[FiscalYearSuffix]
                ,[FiscalCalendarID]
                )
                SELECT
                    [Erp].[GLPeriodBal].[Company]
                   ,[Erp].[GLPeriodBal].[BookID]
                   ,[Erp].[GLPeriodBal].[BalanceAcct]
                   ,[Erp].[GLPeriodBal].[FiscalYear]
                   ,@FiscalPeriod AS [FiscalPeriod]
                   ,[Erp].[GLPeriodBal].[BalanceType]
                   ,[Erp].[GLPeriodBal].[SegValue1]
                   ,[Erp].[GLPeriodBal].[SegValue2]
                    ,[Erp].[GLPeriodBal].[FiscalYearSuffix]
                   ,[Erp].[GLPeriodBal].[FiscalCalendarID]
                FROM
                    [Erp].[GLPeriodBal] WITH (NOLOCK)
                WHERE
                    [Erp].[GLPeriodBal].[Company] IN (@company)
                    AND [Erp].[GLPeriodBal].[FiscalYear]=@FiscalYear
                    AND [Erp].[GLPeriodBal].[FiscalPeriod]<=@FiscalPeriod
                    AND [Erp].[GLPeriodBal].[BalanceType] IN ('D','B')

        SET @FiscalPeriod=@FiscalPeriod+1;  
        end;

/*
SELECT
    LTRIM(RTRIM([PERIODBALANCE].[Company])) AS [Company]
   ,LTRIM(RTRIM([PERIODBALANCE].[BookID])) AS [BookID]
     ,LTRIM(RTRIM(REPLACE([PERIODBALANCE].[BalanceAcct],'|','-'))) AS [BalanceAcct]
    ,LTRIM(RTRIM(ISNULL(NULLIF([PERIODBALANCE].[BalanceType],''),'--'))) AS [BalanceType]
     ,LTRIM(RTRIM(ISNULL(NULLIF([PERIODBALANCE].[FiscalYearSuffix],''),'--'))) AS [FiscalYearSuffix]
   ,LTRIM(RTRIM(ISNULL(NULLIF([PERIODBALANCE].[FiscalCalendarID],''),'--'))) AS [FiscalCalendarID]

FROM
    @PERIODBALANCE AS [PERIODBALANCE]*/

    return
    end

    go
4

1 回答 1

0

该函数返回一个表。只需使用 INSERT 语句从函数中选择。

INSERT INTO dbo.MyTable
SELECT Company, BookID
  FROM Renetest();

这就是您所要求的。但这可以转换为存储过程,避免一起使用函数。

于 2019-09-18T15:43:18.310 回答