sql >> Database >  >> RDS >> Sqlserver

Een query maken van een bovenliggende onderliggende hiërarchietabel

Als u een vast of beperkt aantal niveaus heeft, heeft u mogelijk geen DYNAMIC SQL nodig. 'Ontcijferen' het pad kan worden bereikt met een beetje XML.

Overweeg het volgende:

Voorbeeld:

Declare @YourTable Table ([Parent] varchar(50),[Child] varchar(50))
Insert Into @YourTable Values 
 (null ,'S-1')
,('S-1','S-11')
,('S-1','S-12')
,('S-1','S-13')
,('S-1','S-14')
,('S-1','S-15')
,('S-11','S-111')
,('S-11','S-112')

;with cteP as (
      Select Child
            ,Parent 
            ,PathID = cast(Child as varchar(500))
      From   @YourTable
      Where  Parent is Null
      Union  All
      Select Child  = r.Child
            ,Parent = r.Parent 
            ,PathID = cast(p.PathID+','+cast(r.Child as varchar(25)) as varchar(500))
      From   @YourTable r
      Join   cteP p on r.Parent  = p.Child)
Select [Group] = Child
      ,B.*
 From  cteP A
 Cross Apply (
                Select Level1 = xDim.value('/x[1]','varchar(max)')
                      ,Level2 = xDim.value('/x[2]','varchar(max)')
                      ,Level3 = xDim.value('/x[3]','varchar(max)')
                      ,Level4 = xDim.value('/x[4]','varchar(max)')
                      ,Level5 = xDim.value('/x[5]','varchar(max)')
                From  (Select Cast('<x>' + replace(PathID,',','</x><x>')+'</x>' as xml) as xDim) as X 
             ) B
  Order By PathID

Retourneren




  1. django.core.exceptions.ImproperlyConfigured:fout bij het laden van MySQLdb-module:geen module met de naam MySQLdb

  2. Retour-ID als een rij bestaat, anders INSERT

  3. Het implementeren van Twitter en Facebook-achtige hashtags

  4. Hoe verbinding te maken met MySQL met behulp van PHP