How to notice column changes in trigger

From: Andreas Pflug <Andreas(dot)Pflug(at)web(dot)de>
To: pgsql-sql(at)postgresql(dot)org
Subject: How to notice column changes in trigger
Date: 2003-03-07 10:30:37
Message-ID: 3E6874CD.4090501@web.de
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

How can I detect whether a column was changed by an update command
inside a trigger?

create table test(a int, b int, c int, primary key(a))

b and c should be updated inside an update trigger if not modified by
the statement itself

1) update test set a=0 -> trigger does its work
2) update test set a=0, b=1, c=2 -> trigger does nothing
3) update test set a=0, b=b, c=c -> trigger does nothing, but content of
a and b dont change either although touched

What I'm looking for is something like
IF NOT COLUMN_TOUCHED(b) THEN ...
For MSSQL, this would be coded as IF NOT UPDATE(b) ..

IF OLD.b=NEW.b will not work, case 3) will falsely execute the trigger code.

Any hints?

Andreas

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Andre Schubert 2003-03-07 11:27:19 Re: Help on indexing timestamps
Previous Message Andre Schubert 2003-03-07 10:26:39 Help on indexing timestamps