From: | "Rodrigo De Leon" <rdeleonp(at)gmail(dot)com> |
---|---|
To: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: CREATE TABLE AS inside of a function |
Date: | 2006-07-21 20:32:07 |
Message-ID: | a55915760607211332ye89afd4m9bb2ad456fcef99b@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
On 7/21/06, Kevin Nikiforuk <Kevin(dot)Nikiforuk(at)acrodex(dot)com> wrote:
> So now that I've got my loops working, on to my next newbie question. I've created my function and in it, I want to loop through the results of a select and for each value of my loop counter, I want to create a new table, but I can't figure out how to use a variable in the name of the new table, see below.
>
> CREATE OR REPLACE FUNCTION rgio() RETURNS INTEGER as $$
> DECLARE
> lv RECORD;
>
> BEGIN
> FOR lv IN SELECT DISTINCT rg FROM ldevrg LOOP
> CREATE TABLE rgio_$lv AS
> SELECT ldev
> FROM ldevrg
> WHERE rg='$lv';
> END LOOP;
> RETURN 1;
> END;
> $$ LANGUAGE plpgsql;
>
> Thanks,
> Kevin
See:
http://www.postgresql.org/docs/8.1/static/plpgsql-statements.html#PLPGSQL-STATEMENTS-EXECUTING-DYN
Regards,
Rodrigo
From | Date | Subject | |
---|---|---|---|
Next Message | Erik Jones | 2006-07-21 21:04:37 | Re: CREATE TABLE AS inside of a function |
Previous Message | Kevin Nikiforuk | 2006-07-21 19:14:29 | CREATE TABLE AS inside of a function |