sql >> Databasteknik >  >> RDS >> Sqlserver

Oändlig loop CTE med OPTION (maxrekursion 0)

Om du når rekursionsgränsen har du antingen ett stort djup i sponsringsrelationer eller en loop i data. En fråga som följande kommer att upptäcka loopar och avsluta 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. Hitta och ta bort icke-ASCII-tecken från en Oracle Varchar2

  2. Få den första, andra, tredje eller fjärde måndagen i en månad i SQLite

  3. SQL Server 2017:Importera CSV-data från Linux till Salesforce med SSIS

  4. PostgreSQL:FOREIGN KEY/ON DELETE CASCADE