| From: | Marcus Mascari <mascarim(at)yahoo(dot)com> | 
|---|---|
| To: | pgsql-hackers(at)postgreSQL(dot)org | 
| Subject: | Trigger - Rewrite question with 6.5beta | 
| Date: | 1999-05-20 16:58:39 | 
| Message-ID: | 19990520165839.5777.rocketmail@web113.yahoomail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | 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|goodbye
 2|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(at)yahoo(dot)com)
P.S. The autoinc() is the one from /contrib
_____________________________________________________________
Do You Yahoo!?
Free instant messaging and more at http://messenger.yahoo.com
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Jan Wieck | 1999-05-20 17:03:51 | PL installation | 
| Previous Message | Andy Farrell | 1999-05-20 16:57:46 | Postgres 6.4.2 connection problem |