| From: | Greg Stark <gsstark(at)mit(dot)edu> | 
|---|---|
| To: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> | 
| Cc: | Christian Storm <christian(dot)storm(at)gmail(dot)com>, "Jim C(dot) Nasby" <jnasby(at)pervasive(dot)com>, Josh Berkus <josh(at)agliodbs(dot)com>, pgsql-performance(at)postgresql(dot)org, PFC <lists(at)peufeu(dot)com> | 
| Subject: | Re: pgmemcache | 
| Date: | 2006-04-13 20:52:37 | 
| Message-ID: | 87irpdgpuy.fsf@stark.xeocode.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-performance | 
Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> writes:
> Christian Storm <christian(dot)storm(at)gmail(dot)com> writes:
> > Not sure if I follow why this is a problem.  Seems like it would be  
> > beneficial to have both BEFORE and AFTER COMMIT triggers.
> > With the BEFORE COMMIT trigger you would have the ability to 'un- 
> > commit' (rollback) the transaction.  With
> > the AFTER COMMIT trigger you wouldn't have that option because the  
> > commit has already been successful.  However,
> > with an AFTER COMMIT you would be able to trigger other downstream  
> > events that rely on a transaction successfully committing.
> 
> An AFTER COMMIT trigger would have to be in a separate transaction.
> What happens if there's more than one, and one of them fails?  Even
> more to the point, if it's a separate transaction, don't you have
> to fire all these triggers again when you commit that transaction?
> The idea seems circular.
Maybe it just means they would have to be limited to not making any database
modifications. Ie, all they can do is notify the outside world that the
transaction committed. 
Presumably if you wanted to make any database modifications you would just do
it in the transaction anyways since they wouldn't show up until the
transaction commits.
-- 
greg
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Tom Lane | 2006-04-14 00:36:09 | Re: Blocks read for index scans | 
| Previous Message | PFC | 2006-04-13 20:23:31 | Re: pgmemcache |