Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

Trouver la connectivité des valeurs des colonnes

Je suis presque sûr que vous avez besoin d'un CTE récursif. Cependant, les résultats de votre échantillon n'ont aucun sens.

Ce qui suit fait essentiellement ce que vous voulez :

with cte AS (
      select nod1, nod2, nod_length as Total_length,
             convert(varchar(max), concat('-', nod1, '-', nod2, '-')) as nodes, 1 as lev
      from tbl_nodes n
      where nod1 = 'A'
      union all
      select cte.nod1, n.nod2, cte.Total_length + n.nod_length,
             convert(varchar(max), concat(cte.nodes, n.nod2, '-')) as nodes, lev + 1
      from cte join
           tbl_nodes n
           on cte.nod2 = n.nod1
      where nodes not like concat('%-', n.nod2, '-%') 
     )
select nodes, total_length
from cte
where not exists (select 1
                  from cte cte2
                  where cte2.nodes like concat(cte.nodes, '_%')
                 );

ici est un db<>violon.