Re: CREATE TABLE AS inside of a function

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

In response to

Responses

Browse pgsql-sql by date

  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