sql >> Database teknologi >  >> RDS >> Sqlserver

Anden løsning i stedet for markør

Jeg er ikke sikker på, at du virkelig har brug for en rekursiv forespørgsel så meget som en tal-/optællingstabel for at få de ækvivalente sekvensnumre for de "CURRENT" værdier som for de "PROPOSED" værdier.

With 
    Numbers As 
    (
    Select Row_Number() Over ( Order By C1.object_id ) As Value
    From sys.columns As C1
        Cross Join sys.columns As C2
    )
    , ProposedSequences As
    (
    Select  NTRIId
        , Row_Number() Over ( Order By NTRIId ) As Sequence
    From Table
    Where NTRITCode = 'PROPOSED'
    Group By NTRIId
    )
    , CurrentSequences As
    (
    Select RID, NTRITCode, NTRIId, Parameter, Usage, Rate
        , Numbers.Value As Sequence
    From Table
        Cross Join Numbers
    Where NTRITCode = 'Current'
        And Numbers.Value <= (Select Max(Sequence) From ProposedSequence)
    )
Select Sequence, RID, NTRITCode, NTRIId, Parameter, Usage, Rate
From CurrentSequences
Union All
Select PS.Sequence, T.RID, T.NTRITCode, T.NTRIId, T.Parameter, T.Usage, T.Rate
From ProposedSequences As PS
    Join Table As T
        On T.NTRIId = PS.NTRIId
Order By PS.Sequence, T.NTRITCode


  1. Sådan tilføjes fremmednøglebegrænsning til eksisterende tabel i SQL Server - SQL Server / TSQL vejledning del 68

  2. PL/SQL Tutorial:Alt du behøver at vide om PL/SQL

  3. Overvindelse af begrænsningen på bulkinserts over et databaselink

  4. Hvordan bestemmer man antallet af dage i en måned i SQL Server?