Different handling of PL/pgSQL for-loop variables in 8.3.7 vs. 8.2.7 ??? - Mailing list pgsql-admin

From Atul Chojar
Subject Different handling of PL/pgSQL for-loop variables in 8.3.7 vs. 8.2.7 ???
Date
Msg-id 002d01c9ea09$7376a390$5a63eab0$@com
Whole thread Raw
List pgsql-admin

We recently upgraded from postgres version 8.2.7 to 8.3.7. The below pl/pgsql test function behaves differently in the 2 versions.

 

The code of the function is :-

 

CREATE OR REPLACE FUNCTION "public"."testloop" () RETURNS varchar AS

$body$

BEGIN

    FOR idx IN 1..10 LOOP

        raise notice 'idx=%', idx;

        idx:=idx+1; 

    END LOOP;

    return '';

END;

$body$

LANGUAGE 'plpgsql'

 

The sql :-

 

select testloop();

 

in 8.2.7 returns:-

 

NOTICE:  idx=1

NOTICE:  idx=3

NOTICE:  idx=5

NOTICE:  idx=7

NOTICE:  idx=9

 

But in 8.3.7 returns:-

 

NOTICE:  idx=1

NOTICE:  idx=2

NOTICE:  idx=3

NOTICE:  idx=4

NOTICE:  idx=5

NOTICE:  idx=6

NOTICE:  idx=7

NOTICE:  idx=8

NOTICE:  idx=9

NOTICE:  idx=10

 

So in 8.3.7, the incrementing of the for-loop variable “idx” is being ignored; that is not the case in 8.2.7. Is this a new feature of 8.3.7 or a bug?

 

Since a lot of our functions depend on manual altering of for-loop variables, any prompt help/advise/suggestions would be greatly appreciated!

 

Thanks!

atul

AirFacts, Inc.
8120 Woodmont Ave., Suite 700
Bethesda, MD 20814
Tel: 301-760-7315

 

 

 

Attachment

pgsql-admin by date:

Previous
From: Tom Lane
Date:
Subject: Re: reindexdb -t schema.table name
Next
From: Ricardo Mercado Araneda
Date:
Subject: Sobre Actualizacion