Sequence bug in insert trigger

Поиск
Список
Период
Сортировка
От pgsql-bugs@postgresql.org
Тема Sequence bug in insert trigger
Дата
Msg-id 200011062132.eA6LWPh28764@hub.org
обсуждение исходный текст
Ответы Re: Sequence bug in insert trigger  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-bugs
Sequence bug in insert trigger (rob@cabrion.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.
Updateswork 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

В списке pgsql-bugs по дате отправления:

Предыдущее
От: Lamar Owen
Дата:
Сообщение: Re: index returns different output
Следующее
От: pgsql-bugs@postgresql.org
Дата:
Сообщение: Sending result sets from backend to frontend is _slow_