Sql 低性能基于集合的StoredProcess

Sql 低性能基于集合的StoredProcess,sql,performance,stored-procedures,set-based,Sql,Performance,Stored Procedures,Set Based,我在sql中使用以下基于集合的代码来计算客户账单,但在40000条记录上执行此操作需要3分钟!!!让我知道问题出在哪里 with cte (ID,[Date],Time,DocumentNumber,Title,TopicFK,Description,DocumentHeaderID,Debit,Credit,Balance,[Status]) as ( select ID,[Date],Time,DocumentNumber,Title,TopicFK,Description,Doc

我在sql中使用以下基于集合的代码来计算客户账单,但在40000条记录上执行此操作需要3分钟!!!让我知道问题出在哪里

 with cte (ID,[Date],Time,DocumentNumber,Title,TopicFK,Description,DocumentHeaderID,Debit,Credit,Balance,[Status])
as
(
    select ID,[Date],Time,DocumentNumber,Title,TopicFK,Description,DocumentHeaderID,Debit, Credit, Balance=(case when (Debit>Credit) then abs(Debit) else abs(Credit) end), [Status]=cast((case when (Debit>Credit) then 'Debit' else 'Credit' end)as nvarchar(10))
        from #t1
        where ID = 1
    union all
    select tbl.ID,tbl.[Date],tbl.Time,tbl.DocumentNumber,tbl.Title,tbl.TopicFK,tbl.Description,tbl.DocumentHeaderID,tbl.Debit, tbl.Credit
            , Balance=cast((case when ((tbl.Debit > 0 and cte.[Status] = 'Debit')) then abs(cte.Balance + tbl.Debit)
                when tbl.Debit > 0 and cte.[Status] = 'Credit' then abs(cte.Balance - tbl.Debit)
                when(tbl.Credit > 0 and cte.[Status] = 'Debit') then abs(cte.Balance - tbl.Credit)
                when(tbl.Credit > 0 and cte.[Status] = 'Credit') then abs(cte.Balance + tbl.Credit)
                                end )as decimal(18,0))
            , cast((case when ((tbl.Debit > 0 and cte.[Status] = 'Debit')) then 'Debit'
                when tbl.Debit > 0 and cte.[Status] = 'Credit' then 'Credit'
                when(tbl.Credit > 0 and cte.[Status] = 'Debit') then 'Debit'
                when(tbl.Credit > 0 and cte.[Status] = 'Credit') then 'Credit'

                end )as nvarchar(10)) as [Status]
        from #t1 tbl
            inner join cte cte
            on tbl.ID = cte.ID + 1

)

select [Date],Time,DocumentNumber,Title,TopicFK,Description,DocumentHeaderID, Debit, Credit, Balance, [Status] from cte
option (maxrecursion 0);

[Status]字段将没有索引,因为它是在WITH子句中创建的。我建议您不要在WHERE子句中使用[Status]字段

cast((case when ((tbl.Debit > 0 and cte.Debit>cte.Credit)) then abs(cte.Balance + tbl.Debit)
                when tbl.Debit > 0 and cte.Debit<=cte.Credit then abs(cte.Balance - tbl.Debit)
                when(tbl.Credit > 0 and cte.Debit>cte.Credit) then abs(cte.Balance - tbl.Credit)
                when(tbl.Credit > 0 and cte.Debit<=cte.Credit) then abs(cte.Balance + tbl.Credit)
                                end )as decimal(18,0))
cast(((待结清借方>0,待结清借方>待结清贷方))然后abs(待结清借方+待结清借方)
当tbl.借方>0且cte.借方>0且cte.借方>cte.贷方)时,则abs(cte.余额-tbl.贷方)

当(tbl.Credit>0和cte.Debityou的意思是删除第4,5,6,7行???那么让我知道如何在第14行设置状态字段??第14行或第4,5,6,7行到底是什么?我的意思是,尽管使用了[状态]您应该使用借方和贷方字段。在第二种情况下,您可以存储上一个文档中的这些数据,而不考虑计数和存储状态字段。我尝试了您的解决方案,但没有影响性能!!但我需要存储状态字段,以便在我的报告中为用户显示