Re: CREATE RULE ignored, what did I do wrong

Поиск
Список
Период
Сортировка
От andrew@pillette.com
Тема Re: CREATE RULE ignored, what did I do wrong
Дата
Msg-id 200409131813.i8DID8Y10812@pillette.com
обсуждение исходный текст
Ответ на CREATE RULE ignored, what did I do wrong  (andrew@pillette.com)
Список pgsql-sql
I was trying to implement a pseudo-delete, where the (millions of) records in several child tables were actually
deleted,but a flag was set in the summary table instead of deleting it, as an archiving mechanism. (If the flag was
alreadyset, the WHERE clause in the RULE should be false, and the delete happen as usual?!) The FK relation below has
thesummary table as the child, and isn't critical. It's the tables for which this is the parent that are the issue.
 

Do you have an idea how to implement this best?

Tom Lane <tgl@sss.pgh.pa.us> wrote ..
> andrew@pillette.com writes:
> > Foreign-key constraints:
> >     "$1" FOREIGN KEY (smoothing_id) REFERENCES smoothing_algorithm(smoothing_id)
> ON UPDATE CASCADE ON DELETE CASCADE
> > Rules:
> >     del_smoothed_rank_episode AS ON DELETE TO smoothed_rank_episode
> > WHERE (NOT old.is_deleted) DO INSTEAD ...
> 
> The DELETE commands generated by the foreign key ON DELETE CASCADE will
> get rewritten by your ON DELETE rule.  You probably do not want to do
> this; or at least not make it an INSTEAD rule.
> 
> There has been some debate in the past about whether rules should be
> able to break foreign-key constraints, but I tend to class it as a
> "you should know what you're doing" feature.  Preventing this kind
> of error would inevitably result in a serious reduction of the power
> of the rule feature.
> 
>             regards, tom lane


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

Предыдущее
От: mØntar3
Дата:
Сообщение: Re: create unique index schema.index_name on table (column)?
Следующее
От: Robert Davis
Дата:
Сообщение: explain analyze results are different for each iteration