Re: double linked list - Mailing list pgsql-sql

From hidders@REMOVE.THIS.uia.ua.ac.be (Jan Hidders)
Subject Re: double linked list
Date
Msg-id 3e37dbc8$1@news.uia.ac.be
Whole thread Raw
In response to Re: double linked list  (71062.1056@compuserve.com (--CELKO--))
List pgsql-sql
Juergen wrote:
>
>However, I dont store a consistent tree structure. The table at hand
>is more a kind of a collection of graphs where I want to find all
>possible paths between a given starting point and a given end point

A collection of graphs? As you presented the problem it was simply a single
graph.

That's not possible in a single SQL statement without using some form of
recursion such as the CONNECT BY in Oracle that was already mentioned or the
recursive queries as are possible in RDB. Another "poor man's solution" could for
example be to add a table Reachable(node, from_a, to_b) with 'from_a' and
'from_b' boolean field that indicate that the node is reachable from a and
that b is reachable from this node. You could compute this relation by
repeating a certain SQL update statement that:
1. sets from_a of node n to true if there is a node n' that is reachable  from a and there is an edge from n' to n,
and
2. set to_b of node n to tur if there is a node n' that leads to b and there  is an edge from n to n'.
You repeat that until no more flags are changed. Then you select only those
edges for which the begin and node have both flags set to true.



pgsql-sql by date:

Previous
From: 71062.1056@compuserve.com (--CELKO--)
Date:
Subject: Re: double linked list
Next
From: "Ryan"
Date:
Subject: Re: double linked list