Re: stored procs in postgresql

From: Chris Browne <cbbrowne(at)acm(dot)org>
To: pgsql-sql(at)postgresql(dot)org
Subject: Re: stored procs in postgresql
Date: 2005-09-24 21:27:19
Message-ID: 60vf0qma14.fsf@dba2.int.libertyrms.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

ceremona(at)gmail(dot)com writes:
> I have been having some trouble with plsql stored procs in postgres in
> that I can
> make a table name a variable in the stored proc. Is there some
> special way to make this happen that I am unaware of?
>
> For example, I want to do something like:
>
> stored_proc(integer,varchar)
>
> SELECT table_name.id
> FROM table_name $2
> WHERE table_name.id=$1
>
> but I get an error about the $2 argument being no good.
>
> Does anyone know how I can deal with this?

To do this sort of thing, you need to build up the query as a string,
and EXECUTE it.

Thus...
query := 'select t.id from ' || $2 || ' t where t.id = ' || $1 || ';';

The other vital problem is that the select is in bad form. The actual
name of the table needs to come BEFORE the alias, not after.

The following would represent more nearly legitimate SQL...

SELECT table_name.id
FROM $2 table_name
WHERE table_name.id=$1
--
let name="cbbrowne" and tld="cbbrowne.com" in String.concat "@" [name;tld];;
http://cbbrowne.com/info/spiritual.html
And me, with this terrible pain in all the diodes down my left side...
-- Marvin the Paranoid Android

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Ferindo Middleton Jr 2005-09-25 03:34:15 redundancy in CHECK CONSTRAINTs
Previous Message ceremona 2005-09-24 19:30:58 stored procs in postgresql