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

Infinite loop CTE med OPTION (maxrecursion 0)

Hvis du rammer rekursionsgrænsen, har du enten en betydelig dybde i sponsorforhold eller en sløjfe i dataene. En forespørgsel som den følgende vil opdage loops og afslutte rekursionen:

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. Migrering af en Oracle-database til MySQL på AWS, del 2

  2. Find overlappende datointervaller i PostgreSQL

  3. Find dublerede rækker i SQL Server

  4. SQL Server 2017:Tilgængelige funktioner på Linux