From: | "Linux Guru" <linux(dot)binary(at)gmail(dot)com> |
---|---|
To: | "Albert Cervera Areny" <albert(at)sedifa(dot)com> |
Cc: | pgsql-performance(at)postgresql(dot)org |
Subject: | Re: Creating and updating table using function parameter reference |
Date: | 2008-02-14 12:35:27 |
Message-ID: | 3caa866c0802140435v4af4f2a1y183883db977eb151@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-performance |
I still cannot pass tablename, what is wrong?
Is this the right way?
CREATE OR REPLACE FUNCTION test ( t1 text,t2 text ) RETURNS numeric AS $$
declare temp1 text;
declare temp2 text;
declare cmd text;
declare t2row RECORD;
begin
temp1=t1;
temp2=t2;
cmd='select product, (case when sum(pd) <> 0 then sum(gd)/sum(pd)*100
else 0 end ) as gppp
from ' temp1 ' as dummy group by dummy.product,dummy.totalclaimsgroup,
dummy.avgmems,dummy.months';
execute cmd into t2row
--After executing above, I need here to update table t1
end;
$$ LANGUAGE plpgsql
----------------
ERROR: syntax error at or near "$1"
LINE 2: from ' $1 ' as dummy group by dummy.product,dummy.totalcla...
^
QUERY: SELECT 'select product, (case when sum(pd) <> 0 then
sum(gd)/sum(pd)*100 else 0 end ) as gppp
from ' $1 ' as dummy group by dummy.product,dummy.totalclaimsgroup,
dummy.avgmems,dummy.months'
CONTEXT: SQL statement in PL/PgSQL function "test" near line 9
********** Error **********
ERROR: syntax error at or near "$1"
SQL state: 42601
Context: SQL statement in PL/PgSQL function "test" near line 9
On Wed, Feb 13, 2008 at 8:23 PM, Albert Cervera Areny <albert(at)sedifa(dot)com>
wrote:
> A Dimecres 13 Febrer 2008 15:25, Linux Guru va escriure:
> > I want to create and update two tables in a function such as below, but
> > using parameters as tablename is not allowed and gives an error. Is
> there
> > any way I could achieve this?
>
> You're looking for EXECUTE:
>
> http://www.postgresql.org/docs/8.3/static/plpgsql-statements.html#PLPGSQL-STATEMENTS-EXECUTING-DYN
>
> >
> > CREATE OR REPLACE FUNCTION test ( t1 text,t2 text ) RETURNS numeric AS
> $$
> > declare temp1 text;
> > declare temp2 text;
> > begin
> > temp1=t1;
> > temp2=t2;
> > select
> > product,
> > (case when sum(pd) <> 0 then sum(gd)/sum(pd)*100 else 0 end ) as gppp
> > into temp2 from temp1 as dummy
> > group by dummy.product,dummy.totalclaimsgroup,dummy.avgmems,dummy.months
> ;
> >
> > update temp1 as t set
> > GPPP=(select gppp from temp2 as dummy where dummy.product=t.product),
> >
> > end
> > $$ LANGUAGE plpgsql
> >
> >
> > ----------------------
> > ERROR: syntax error at or near "$1"
> > LINE 1: ...en sum(gd)/sum(pd)*100 else 0 end ) as gppp from $1 as
> dum...
> > ^
> > QUERY: select product, (case when sum(pd) <> 0 then sum(gd)/sum(pd)*100
> > else 0 end ) as gppp from $1 as dummy group by dummy.product,
> > dummy.totalclaimsgroup,dummy.avgmems,dummy.months
> > CONTEXT: SQL statement in PL/PgSQL function "test" near line 10
> >
> > ********** Error **********
> >
> > ERROR: syntax error at or near "$1"
> > SQL state: 42601
> > Context: SQL statement in PL/PgSQL function "test" near line 10
>
>
>
From | Date | Subject | |
---|---|---|---|
Next Message | Albert Cervera Areny | 2008-02-14 12:54:28 | Re: Creating and updating table using function parameter reference |
Previous Message | Thomas Zaksek | 2008-02-14 10:57:07 | Re: Join Query Perfomance Issue |