i'm quite new to postgres. i want to create a function (like stored procedure) that updates multiple 开发者_开发知识库rows and selects affected rows.
here is my statement:
CREATE or replace FUNCTION set_val(
_val character varying(100) ) --5
RETURNS setof "table_test" AS
$body$
declare results "table_test"%rowtype;
begin
update "table_test"
set "value" = $1
where "gender" = 'm'
returning * into results;
if not found then
insert into "table_test"("value")
values($1)
returning * into results;
end if;
return next results;
end;
$body$
LANGUAGE 'plpgsql' ;
it works fine as long as only 1 row was affected. but when more rows are affected, it doesn't.
When a PL/pgSQL function has to return setof it has to use "RETURN NEXT" or "RETURN QUERY".
i finally got it i use for loop with return next. thanks
here's my code
declare result table1%rowtype;
begin
for result in update table1 set ... where ... returning * loop
return next result;
end loop;
end;
精彩评论