I have a table similar to this:
CREATE TABLE example ( id integer primary key, name char(200), parentid integer, value integer);
I can use the parentid field to arrange data into a tree structure.
Now here’s the bit I can’t work out. Given a parentid, is it possible to write an SQL statement to add up all the value fields under that parentid and recurse down the branch of the tree ?
UPDATE: I’m using posgreSQL so the fancy MS-SQL features are not available to me. In any case, I’d like this to be treated as a generic SQL question.
There are a few ways to do what you need in PostgreSQL.
If you can install modules, look at the tablefunc contrib. It has a connectby() function that handles traversing trees. http://www.postgresql.org/docs/8.3/interactive/tablefunc.html
Also check out the ltree contrib, which you could adapt your table to use: http://www.postgresql.org/docs/8.3/interactive/ltree.html
Or you can traverse the tree yourself with a PL/PGSQL function.
Something like this: