sql >> Database >  >> RDS >> Sqlserver

Oneindige lus CTE met OPTIE (maxrecursion 0)

Als u de recursielimiet bereikt, heeft u ofwel aanzienlijke diepgang in sponsorrelaties of een lus in de gegevens. Een query als de volgende zal lussen detecteren en de recursie beëindigen:

declare @tblMember as Table ( MemberId Int, SponsorMemberId Int );
insert into @tblMember ( MemberId, SponsorMemberId ) values
  ( 1, 2 ), ( 2, 3 ), ( 3, 5 ), ( 4, 5 ), ( 5, 1 ), ( 3, 3 );
declare @MemberId as Int = 3;
declare @False as Bit = 0, @True as Bit = 1;

with Children as (
  select MemberId, SponsorMemberId,
    Convert( VarChar(4096), '>' + Convert( VarChar(10), MemberId ) + '>' ) as Path, @False as Loop
    from @tblMember
    where MemberId = @MemberId
  union all
  select Child.MemberId, Child.SponsorMemberId,
    Convert( VarChar(4096), Path + Convert( VarChar(10), Child.MemberId ) + '>' ),
    case when CharIndex( '>' + Convert( VarChar(10), Child.MemberId ) + '>', Path ) = 0 then @False else @True end
    from @tblMember as Child inner join
      Children as Parent on Parent.MemberId = Child.SponsorMemberId
    where Parent.Loop = 0 )
  select *
    from Children
    option ( MaxRecursion 0 );



  1. SYS-wachtwoord wijzigen in RAC

  2. Aankondiging van ClusterControl 1.7.2:verbeterde PostgreSQL-back-up en ondersteuning voor TimescaleDB en MySQL 8.0

  3. Hoe detecteer je dat de transactie al is gestart?

  4. 'IF' in 'SELECT'-statement - kies uitvoerwaarde op basis van kolomwaarden