PL/pgsql: function passing argument to IN operator

From: "Daniel Myers" <danielsmyers(at)gmail(dot)com>
To: pgsql-sql(at)postgresql(dot)org
Subject: PL/pgsql: function passing argument to IN operator
Date: 2007-12-29 06:40:03
Message-ID: 455d64770712282240h3c93a2f0y9e357d1d23882b10@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Hello list,
I'm trying to write a function that uses one of its arguments as
an input to an IN operator in a WHERE clause. I.e., something like:

-- ids are actually integers
CREATE FUNCTION foo(ids SOMETYPE) RETURNS [whatever] AS $$
BEGIN
SELECT id, [other stuff] FROM table WHERE [other conditions] AND
id IN (ids);
RETURN;
END
$$ plpgsql

I had wanted to avoid using the EXECUTE statement and dynamically
creating the query string, because 1) I'd rather not recompile the
query each time and 2) I'm doing a SELECT INTO, which apparently
doesn't work with EXECUTE.

Can anyone help me out?

Thanks,
Daniel

P.S.: Sorry if capitalizing SQL keywords is bad list etiquette...

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Pavel Stehule 2007-12-29 07:29:22 Re: PL/pgsql: function passing argument to IN operator
Previous Message Marcin Stępnicki 2007-12-29 02:09:35 Re: Advice for generalizing trigger functions