Trigger - Rewrite question with 6.5beta - Mailing list pgsql-hackers

From Marcus Mascari
Subject Trigger - Rewrite question with 6.5beta
Date
Msg-id 19990520165839.5777.rocketmail@web113.yahoomail.com
Whole thread Raw
Responses Re: [HACKERS] Trigger - Rewrite question with 6.5beta  (jwieck@debis.com (Jan Wieck))
List pgsql-hackers
While on the subjects of triggers, is this the 
proper behavior?

t=> SELECT version();
version                                                      
------------------------------------------------------
PostgreSQL 6.5.0 on i586-pc-linux-gnu, 
compiled by gcc 2.7.2.
(1 row)

t=> CREATE TABLE TEST1 (
t-> id int4, 
t-> value text not null);
CREATE

t=> CREATE TABLE TEST2 (
t-> value text not null);
CREATE

t=> CREATE SEQUENCE TESTSEQ;
CREATE

t=> CREATE TRIGGER T_TEST1 BEFORE INSERT ON TEST1 
t-> FOR EACH ROW EXECUTE PROCEDURE 
t-> autoinc(id, TESTSEQ);
CREATE

t=> INSERT INTO TEST2 VALUES ('hello');
INSERT 2497567 1

t=> INSERT INTO TEST2 VALUES ('hello');
INSERT 2497568 1

t=> INSERT INTO TEST2 VALUES ('goodbye');
INSERT 2497569 1

t=> INSERT INTO TEST1 (value) 
t-> SELECT DISTINCT value FROM TEST2;
NOTICE:  testseq.nextval: sequence was re-created
INSERT 0 3

t=> SELECT * FROM TEST1;
id|value  
--+-------1|goodbye2|hello  3|hello  
(3 rows)

I guess I was expecting the DISTINCT in the 
SELECT to suppress the fetching of the second 
'hello' record, then the insert is performed, and, 
while the insert is performed, the trigger procedure
is executed to fetch the sequence value for 2
rows, not 3.  Is this related to the same 
conditions which make the use of DISTINCT on VIEWS
problematic?

Thanks for any info, 

Marcus Mascari (mascarim@yahoo.com)

P.S. The autoinc() is the one from /contrib




_____________________________________________________________
Do You Yahoo!?
Free instant messaging and more at http://messenger.yahoo.com


pgsql-hackers by date:

Previous
From: Andy Farrell
Date:
Subject: Postgres 6.4.2 connection problem
Next
From: jwieck@debis.com (Jan Wieck)
Date:
Subject: PL installation