绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
greenplum 递归函数
2023-03-17 15:59:54

在低版本的greenplum中不支持递归.所以可以写一个函数来支持

CREATE OR REPLACE FUNCTION with_recursive(
id bigint[],
table_name character varying,
id_name character varying,
pid_name character varying)
RETURNS bigint[] AS
$BODY$
declare
vsql text;
ids int8[];
begin
if(id is null) then return null; end if;

vsql ='select array_agg('|| id_name ||') from ' || table_name ||
' where 1=1 and ' || pid_name || '=any(array['|| array_to_string(id,',') || '])';
--raise notice 'vsql:%',vsql;

if(vsql is not null) then execute vsql into ids;end if;

vsql ='select subids from (select array_cat(array['|| array_to_string(id,',') ||
']::int8[],with_recursive(array['|| array_to_string(ids,',') ||
'],'''|| table_name ||''','''||id_name||''','''||pid_name||''')) subids) t';
--raise notice 'vsql:%',vsql;

if(vsql is not null) then execute vsql into ids;end if;

return coalesce(ids,id);

end $BODY$
LANGUAGE plpgsql VOLATILE;
ALTER FUNCTION with_recursive(bigint[], character varying, character varying, character varying)
OWNER TO gpadmin;
COMMENT ON FUNCTION with_recursive(bigint[], character varying, character varying, character varying) IS '递归函数';

使用

select unnest(with_recursive(array[4],'chains','cid','pid')) subchains;




本文来源: http://udn.yyuap.com/thread-114853-1-1.html


分享好友

分享这个小栈给你的朋友们,一起进步吧。

Greenplum
创建时间:2022-04-08 15:36:19
Greenplum
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • itt0918
    专家
戳我,来吐槽~