On Friday 17 March 2006 15:33, Emi Lu wrote:
> >>Does not work either, the whole function is:
> >>
> >>create table t1(col1 varchar(3), col2 varchar(100));
> >>insert into t1 values('001', 'Result 1');
> >>insert into t1 values('002', 'Result 2');
> >>insert into t1 values('003', 'Result 3');
> >>
> >>CREATE OR REPLACE FUNCTION test(VARCHAR) RETURNS VARCHAR AS $$
> >>DECLARE
> >> col1_value ALIAS FOR $1;
> >>cm_tableName st1_legend.code_map_tablename%TYPE;
> >>lengendTableName VARCHAR := 't1';
> >> query_value VARCHAR ;
> >>BEGIN
> >>
> >> SELECT INTO cm_tableName col2 FROM lengendTableName WHERE col1 =
> >>col1_value ;
> >
> >This can't work, read the docu:
> >http://www.postgresql.org/docs/8.1/interactive/plpgsql-statements.html#PLP
> >GSQL-STATEMENTS-EXECUTING-DYN
> >
> >You should build a string with your SQL and EXECUTE this string.
>
> Thank you Andreas. Unfortunately it did not work. maybe I made something
> wrong?
>
> drop table t1;
> create table t1(col1 varchar(3), col2 varchar(100));
> insert into t1 values('001', 'Result 1');
> insert into t1 values('002', 'Result 2');
> insert into t1 values('003', 'Result 3');
>
> CREATE OR REPLACE FUNCTION test(VARCHAR) RETURNS VARCHAR AS $$
> DECLARE
> col1_value ALIAS FOR $1;
> cm_tableName st1_legend.code_map_tablename%TYPE;
> lengendTableName VARCHAR := 't1';
> query_value VARCHAR ;
> BEGIN
> query_value := 'SELECT col2 FROM lengendTableName WHERE col1 = \'' ||
> col1_value || '\'';
>
> EXECUTE query_value INTO cm_tableName;
>
> RETURN cm_tableName;
> END;
> $$ language 'plpgsql' IMMUTABLE STRICT;
> select test('001');
>
This function would work on 8.1, provided you created the sql statement
correctly:
query_value := 'SELECT col2 FROM ' ||lengendTableName||' WHERE col1 = \'' ||
col1_value || '\'';
>
> I am using postgresql 8.0.1, and I am afraid that 8.0 does not support
> "excecute ... into ...."
>
In which case you could use:
FOR cm_tableName IN EXECUTE query_value LOOPRETURN cm_tableNameEND LOOP
which is a little hacky, though you could use a second variable for assignment
if you felt strongly about it.
--
Robert Treat
Build A Brighter Lamp :: Linux Apache {middleware} PostgreSQL