On Thu, Aug 7, 2014 at 8:12 AM, Vik Fearing <vik.fear...@dalibo.com> wrote:
>
> Just export the order from your CTE.
>
> WITH RECURSIVE tree AS (
>     SELECT dr.id,
>            ...,
>            array[dr.id] as path,
>            1 as depth,
>            row_number() over (order by dr.num_votes desc) as sort_order
>     FROM discussion_response AS dr
>     WHERE dr.reply_parent_id IS NULL
>       AND dr.discussion_id = 2763
>
>     UNION ALL
>
>     SELECT dr.id,
>            ...,
>            tree.path || dr.id,
>            tree.depth + 1
>            row_number() over (order by dr.num_votes desc)
>     FROM discussion_response AS dr
>     JOIN tree ON tree.id = dr.reply_parent_id
>     WHERE NOT array[dr.id] <@ tree.path
> )
> SELECT *
> FROM tree
> ORDER BY depth, sort_order
> LIMIT 50;
>

It looks like this clobbers the hierarchy by sorting by depth first. I'm
trying to preserve said hierarchy so I can paginate using OFFSET/LIMIT
easily. I'm not sure what I'm shooting for is even possible, though.

-- 
Greg Taylor
http://gc-taylor.com

Reply via email to