![](/img/trans.png)
[英]Writing recursive SQL query that calls function (postgreSQL)
[英]Use a recursive query in a PostgreSQL function
我有一个带有(id,name,parent_id)列的表文件夹。 作为父文件夹的文件夹是parent_id = -1。 我需要获取每个文件夹的顶级父ID。 以下查询工作正常,但不适用于spring data jpa。
WITH RECURSIVE nodes_cte AS (
SELECT tn.id, tn.parent_id, tn.name, tn.id top_id
FROM folder AS tn
WHERE tn.parent_id =-1
UNION ALL
SELECT c.id, c.parent_id, c.name, p.top_id
FROM nodes_cte AS p, folder AS c
WHERE c.parent_id = p.id
)
SELECT distinct * FROM nodes_cte
如何创建将返回与上述查询相同结果的postgresql函数?
创建一个返回表的SQL函数:
CREATE OR REPLACE FUNCTION my_function()
RETURNS TABLE (id int, parent_id int, name text, top_id int)
LANGUAGE SQL AS $$
WITH RECURSIVE nodes_cte AS (
SELECT tn.id, tn.parent_id, tn.name, tn.id top_id
FROM folder AS tn
WHERE tn.parent_id =-1
UNION ALL
SELECT c.id, c.parent_id, c.name, p.top_id
FROM nodes_cte AS p, folder AS c
WHERE c.parent_id = p.id
)
SELECT distinct * FROM nodes_cte
$$;
--use:
SELECT *
FROM my_function();
注意,返回表中的name
列应与表folder
中的类型相同。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.