sql >> Databáze >  >> RDS >> PostgreSQL

Postgres skupina podle dotazu

Pro svůj rekurzivní dotaz můžete vytvořit hierarchickou cestu pomocí tohoto triku s nulovými řetězci:SQL Fiddle

with recursive comment_list(article_comment_id, parent_comment_id, comment, article_id, comment_depth, comment_path) AS (
    select c.article_comment_id, 
           c.parent_comment_id, 
           c.comment, 
           c.article_id, 
           c.comment_depth,
           substr(CAST(1000000000+c.article_comment_id as varchar(1000)),2)
    from test_comment c
    where article_id = 100
      and parent_comment_id = 0

  union all

    select c.article_comment_id, 
           c.parent_comment_id, 
           c.comment, 
           c.article_id, 
           c.comment_depth,
           cl.comment_path || substr(CAST(1000000000+c.article_comment_id as varchar(1000)),2)
    from test_comment c
       join comment_list cl on c.parent_comment_id = cl.article_comment_id
)
select cl.article_comment_id,
     cl.comment_path, 
     cl.parent_comment_id,
     cl.comment, 
     cl.article_id,
     cl.comment_depth
from comment_list cl
order by cl.comment_path, cl.article_comment_id, cl.comment_depth;

Pusťte GROUP BY. Chcete je "seskupit" pro zobrazení, což je ve skutečnosti "ORDER BY"

select cl.parent_comment_id, 
     cl.article_comment_id,
     cl.comment, 
     cl.article_id,
     cl.comment_depth
from comment_list cl
order by cl.parent_comment_id, cl.article_comment_id, cl.comment_depth;

Můžete, ale nemusíte stále potřebovat cl.root_id v pořadí podle, takže by to mohlo být

order by cl.root_id, cl.parent_comment_id, cl.article_comment_id, cl.comment_depth;



  1. Převeďte řádky na sloupce Oracle SQL

  2. Při použití v SELECT INTO nebyla vyvolána výjimka NO_DATA_FOUND

  3. Jak povolit automatické opětovné připojení klienta MySQL k MySQLdb?

  4. Pomoc s kódem SQL pro nalezení nejnovějšího záznamu na základě ID