sql >> Databáze >  >> RDS >> Sqlserver

Nekonečná smyčka CTE s OPTION (max. rekurze 0)

Pokud narážíte na limit rekurze, máte buď značnou hloubku ve sponzorských vztazích, nebo smyčku v datech. Dotaz, jako je následující, detekuje smyčky a ukončí rekurzi:

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. Mysql:Objednat podle like?

  2. Smazat pomocí Join v MySQL

  3. 5 výhod, které můžete využít při upgradu databáze

  4. C#:Předá uživatelsky definovaný typ uložené proceduře Oracle