sql >> Databasteknik >  >> RDS >> PostgreSQL

Postgres grupp efter fråga

För din rekursiva fråga kan du skapa en hierarkisk väg med detta trick med 0-stoppade strängar: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;

Släpp GROUP BY. Du vill "gruppera" dem för visning, vilket egentligen är "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;

Du kanske fortfarande behöver cl.root_id i ordning efter, så det kan vara

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



  1. Oracle:Aritmetisk operation resulterade i ett spill

  2. H2 - Fel vid åtkomst till länkad tabell med SQL-sats SELECT * FROM null T

  3. Ogiltig UTF-8-teckensträng vid import av en CSV-fil till en MySQL-databas

  4. Parallellism kommer till VAKUUM