I am trying to convert a function in Postgres to a select query, which I intend to use as a view. The reason is that I would like to access it from the client using a select query with a where clause instead of using a parameter, as with a function. A table is a tree (and an adjacency list) and is defined as follows:
CREATE TABLE tree ( id serial primary key, parent_id int references tree(id) ); INSERT INTO tree (id, parent_id) VALUES (1,null) , (2,1), (3,2), (4,3), (5,3) , (6,5), (7,6), (8,4), (9,8) , (10,9), (11,9), (12,7) , (13,12), (14,12), (15,11) , (16,15), (17,16), (18,14) , (19,13), (20,19), (21,20); SELECT setval ('tree_id_seq', 21); -- reset sequence -- This produces a tree like: -- +-- <10> -- / -- +-- <4> -- <8> --- <9> -+- <11> --- <15> --- <16> --- <17> -- / -- <1> --- <2> --- <3> -+ -- \ -- +-- <5> --- <6> --- <7> --- <12> -+- <14> --- <18> -- \ -- \ -- \ -- \ -- +-- <13> --- <19> --- <20> --- <21> --
To get the path from any node in the tree to the root in order, I use this function:
create or replace function _tree(rev int) returns table(id int, parent_id int, depth int) as $$ declare sql text; begin sql = 'WITH RECURSIVE tree_list(id, parent_id, depth) AS ( SELECT id, parent_id, 1 FROM tree WHERE id = ' || rev || 'UNION SELECT p.id, p.parent_id, r.depth + 1 FROM tree p, tree_list r WHERE p.id = r.parent_id ) SELECT id, parent_id, depth FROM tree_list order by id;'; return query execute sql; end; $$ language plpgsql;
The query will look like select * from _tree(15) . The question is, how do I go about converting this function to a view, so I could call select * from tree where id <= 15 . In addition, will the view be executed at the same speed as the function (i.e., will the where clause be considered when executing the request)?