Re: Efficient ON DELETE trigger when referential integrity is

Поиск
Список
Период
Сортировка
От Stephan Szabo
Тема Re: Efficient ON DELETE trigger when referential integrity is
Дата
Msg-id 20021112082305.V67144-100000@megazone23.bigpanda.com
обсуждение исходный текст
Ответ на Efficient ON DELETE trigger when referential integrity is involved ?  (Cédric Dufour (Cogito Ergo Soft)<cedric.dufour@cogito-ergo-soft.com>)
Список pgsql-sql
On Tue, 12 Nov 2002, [iso-8859-1] C�dric Dufour (Cogito Ergo Soft) wrote:

> Hello,
>
> I am trying to figure out how to handle tuple deletion efficiently when ON
> DELETE triggers and referential integrity are involved. The scenario is
> about this one:
>
> I have a MASTER and a SLAVE table, the latter referencing the former through
> a "FOREIGN KEY ... REFERENCES ... ON DELETE CASCADE" constraint. Besides, I
> have a ON DELETE trigger on the SLAVE table which updates a field in the
> MASTER table upon deletion.
>
> Now, there no need to update the MASTER table if the SLAVE table deletion
> was actually fired by the FOREIGN KEY constraint. The ON DELETE trigger
> updates a tuple in the MASTER table which will be deleted itself right
> after. This can make the deletion of a MASTER table tuple very slow, if
> there are a lot of related tuples in the SLAVE table.
>
> Is there any "by the book" way to handle this ?

Hmm, by the time that the on delete trigger runs after the foreign key
action, I believe that the row in MASTER is already gone.  Running a
simple test in 7.3 seems to confirm this.  Unfortunately it's still going
to look for the row to update it.  I can't think of a good way to tell
if you're in an action that was caused by a foreign key rather than some
other user trigger or rule or straight delete apart from some vague
notions of really complicated workarounds which only partially help.




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

Предыдущее
От: Christoph Haller
Дата:
Сообщение: Re: averaging interval values
Следующее
От: Luis Sousa
Дата:
Сообщение: Re: Permission on insert rules