Re: Foreign key reference counting strategy?

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: Foreign key reference counting strategy?
Дата
Msg-id 13525.1160870286@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Re: Foreign key reference counting strategy?  (Michael Fuhr <mike@fuhr.org>)
Ответы Re: Foreign key reference counting strategy?
Список pgsql-sql
Michael Fuhr <mike@fuhr.org> writes:
> On Sat, Oct 14, 2006 at 03:52:04PM +0200, Markus Schaber wrote:
>> Create an "after delete" trigger on the referencing table that checks
>> whether there still are records with the same key (IF EXISTS()), and
>> deletes the referenced row otherwise.

> In a concurrent environment that delete can fail with a foreign key
> constraint violation because IF EXISTS won't see uncommitted changes
> in other transactions.

No, I don't think so, because the DELETE will already be holding
exclusive lock on the doomed PK row, which any would-be inserters of
matching FK rows will be blocked on.  AFAICS the DELETE should go
through and then the inserters will fail.  Which is not necessarily
better of course ... but if you want logic like this, you probably
should have code to make the FK inserters deal with no-such-key
failures.
        regards, tom lane


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

Предыдущее
От: Michael Fuhr
Дата:
Сообщение: Re: Foreign key reference counting strategy?
Следующее
От: Michael Fuhr
Дата:
Сообщение: Re: Foreign key reference counting strategy?