Re: BEFORE UPDATE Triggers

Поиск
Список
Период
Сортировка
От Jan Wieck
Тема Re: BEFORE UPDATE Triggers
Дата
Msg-id 3F52AAF2.2000104@Yahoo.com
обсуждение исходный текст
Ответ на Re: BEFORE UPDATE Triggers  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-sql

Tom Lane wrote:
> Jan Wieck <jan@black-lion.info> writes:
>> Unfortunately, you're right. There is no way do distinguish in a trigger 
>> or rule if a value in the new row did result from the UPDATE query or 
>> from target list expansion with OLD values.
> 
>> It would not be terribly hard to examine the original query during 
>> executor start, looking for bare OLD referencing Var nodes, and stick 
>> something like a flag array into the trigger information.
> 
> People keep suggesting this, but I've never thought it was a very sane
> idea.  What if some BEFORE trigger upstream of yours changes the column?
> You won't find that out unless you actually compare the OLD and NEW
> column values.  If you assume the column has not changed just because
> the original query text didn't change it, you are in for a world of hurt.

That's exactly why I allways ask to look at it from a business process 
point of view. The NEW data that will be persistent when the transaction 
commits has to match the new status of the business process. Where this 
data exactly is coming from, got manipulated or how it got there is not 
really relevant. What counts is that the system transforms from one 
consistent state into another in an ACID transaction.


Jan

-- 
#======================================================================#
# It's easier to get forgiveness for being wrong than for being right. #
# Let's break this rule - forgive me.                                  #
#================================================== JanWieck@Yahoo.com #



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

Предыдущее
От: "Dan Langille"
Дата:
Сообщение: Re: Getting the return type right for SETOF
Следующее
От: weigelt@metux.de
Дата:
Сообщение: Re: disabling triggers