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

SQL rekurzivní dotaz, který získá všechny předky položky

with name_tree as (
   select id, parent_id, name
   from the_unknown_table
   where id = 1 -- this is the starting point you want in your recursion
   union all
   select c.id, c.parent_id, c.name
   from the_unknown_table c
     join name_tree p on p.parent_id = c.id  -- this is the recursion
) 
select *
from name_tree
where id <> 1; -- exclude the starting point from the overall result

SQLFiddle:http://sqlfiddle.com/#!3/87d0c/1



  1. Recenze produktu – Stellar Repair pro MySQL

  2. Běží server na hostiteli localhost (::1) a přijímá připojení TCP/IP na portu 5432?

  3. Problém integrity vztahu „jeden k mnoha“ pro časové rozsahy

  4. Reprezentující budoucí čas v PostgreSQL