Sequence bug in insert trigger

From: pgsql-bugs(at)postgresql(dot)org
To: pgsql-bugs(at)postgresql(dot)org
Subject: Sequence bug in insert trigger
Date: 2000-11-06 21:32:25
Message-ID: 200011062132.eA6LWPh28764@hub.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

Sequence bug in insert trigger (rob(at)cabrion(dot)com) reports a bug with a severity of 2
The lower the number the more severe it is.

Short Description
Sequence bug in insert trigger

Long Description
Insert triggers always read sequences at their min (or start) value. This only occurs when triggerd by an insert. Updates work as expected.

ALL access to sequence's value returns the same insider an insert trigger!

everywhere else: currval(seq) = 9

in insert trigger:

nextval(seq) = 1;
currval(seq) = 1;
seq.last_val = 1;

The sample below uses only one function and only one trigger. You can split them up any way you like, it still doesn't work.

I am: RedHat 6.2 (generic) Postgres 7.0.2 (generic from rpm's)

Happy hunting!

Sample Code
--just paste this into psql, make sure you have plpgsql installed

create sequence ____version_seq____;

create table test_table (name text, ____rowver____ int4);

create function sync_test_ver() returns opaque as
'begin
if TG_OP = ''INSERT'' then
if new.____rowver____ isnull then
new.____rowver____ := nextval(''____version_seq____'');
end if;
return NEW;
end if;

if new.____rowver____ = old.____rowver____ then
new.____rowver____ := nextval(''____version_seq____'');
end if;
return NEW;
end;' language 'plpgsql';

create trigger test_trigger before insert or update on test_table for
each row execute procedure sync_test_ver();

insert into test_table values('jim');
--Doh! ____rowver____ = 1 (should be 2)
select * from test_table;

update test_table set name = name;
--yeah! ____rowver____ = 2
select * from test_table;

insert into test_table values('joe');
--Doh! ____rowver____ = 1 (should be 3)
select * from test_table;

No file was uploaded with this report

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message pgsql-bugs 2000-11-06 22:21:06 Sending result sets from backend to frontend is _slow_
Previous Message Lamar Owen 2000-11-05 01:51:22 Re: index returns different output