我在plpgsql中做了以下功能。它工作正常,它返回'OK'
,但由于某种原因它没有在表temp
表中输入任何内容。plpgsql函数无结果
CREATE OR REPLACE FUNCTION public.get_route(node integer[])
RETURNS character varying AS
$BODY$DECLARE
i int := 0;
_r record;
vertex int;
BEGIN
FOREACH i IN ARRAY node
LOOP
IF(i < (array_length(node, 1) - 1))
THEN
FOR _r IN EXECUTE 'select * from shortest_path(''
select id as id, source_id::int4 as source, target_id::int4 as target, cost, reverse_cost
from network_of_point'','|| node[i] ||','|| node[i+1] ||', true, true)'
LOOP
vertex := _r.vertex_id;
EXECUTE 'insert into temp
select nextval(''road_intersection_id_seq''), point
from distinct_network_point
where distinct_network_point.id ='|| vertex;
END LOOP;
i = i + 1;
END IF;
END LOOP;
RETURN 'OK';
END;$BODY$
以下是我使用调用该函数的synatx:
select get_route('{2,7}')
您在调用函数后执行'COMMIT'吗? – 2013-03-05 16:43:40
你提交什么意思?显然,如果你的意思是这样的话,我已经完成了对查询的执行。 @IgorRomanchenko – 2013-03-05 17:45:22
尝试在执行前打印顶点的值。如果它为空,则查询将失败。 – 2013-03-05 18:11:59