As Tom said, you need to declare tmp_var as per the result set coming from
select distinct (value) column.
I gave a try on it.

create or replace function prn_test() returns void as $$
declare
    tmp_var test_table.name%type;         ///Test_table with name column
which is varchar(20) in my case
begin
     for tmp_var in (select distinct name from test_table)
     loop
         raise notice 'Give anything here :) ... !!!';
         update test_table set name=tmp_var;
     end loop;
end;
$$ language plpgsql;


---
Regards,
Raghavendra
EnterpriseDB Corporation
Blog: http://raghavt.blogspot.com/



On Sat, May 19, 2012 at 2:10 AM, Tom Lane <t...@sss.pgh.pa.us> wrote:

> "J.V." <jvsr...@gmail.com> writes:
> >      for tmp_var in select distinct(value) from mytable where
> > value2='literal'
> > tmp_var has to be in  ' ' ticks or will not work.  it is failing on the
> > first FOR statment stating:  "invalid input syntax for integer:
> > "some_distinct_value".
>
> Um, how do you have tmp_var declared?  plpgsql seems to be acting
> as though it's an integer variable, which is not what you need if
> "value" is a varchar.
>
>                        regards, tom lane
>
> --
> Sent via pgsql-general mailing list (pgsql-general@postgresql.org)
> To make changes to your subscription:
> http://www.postgresql.org/mailpref/pgsql-general
>

Reply via email to