From: | "Carla Mello" <carla(dot)mello(at)widesoft(dot)com(dot)br> |
---|---|
To: | <pgsql-sql(at)postgresql(dot)org> |
Subject: | Executing dynamic queries (EXECUTE) |
Date: | 2004-01-27 15:25:56 |
Message-ID: | 013d01c3e4e9$dbe16300$16011aac@widesoft.com.br |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Hello!
I need to execute a dynamic query and capture your result in a integer variable.
I´m using the statement "EXECUTE string", but I don´t obtain to capture the result of dynamic query.
See the example:
======================================================
create or replace function f_population_check() returns bigint as
'
declare
v_tot bigint;
v_query varchar(4000);
v_count integer;
r record;
begin
v_tot:= 0;
for r in select * from pg_tables loop
v_count:= 0;
v_query := ''select count(*) from '' || r.tablename;
v_count:= EXECUTE v_query;
if v_count = 0 then
RAISE NOTICE ''Empty table % '',r.tablename;
end if;
v_tot:= v_tot + 1;
end loop;
return v_tot;
end;
'
language 'plpgsql';
======================================================
ERROR: parse error at or near "$1" at character 18
CONTEXT: PL/pgSQL function "f_population_check" line 11 at assignment
======================================================
Somebody could help me?
Thanks, Carla Mello.
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2004-01-27 16:58:39 | Re: PgSQL Down |
Previous Message | Devrim GUNDUZ | 2004-01-27 11:55:15 | Re: [SQL] PgSQL Down |