timestamp_trigger/Timestamp_update_trigger_v1...

32 lines
828 B
PL/PgSQL

CREATE OR REPLACE FUNCTION timestamp_update()
RETURNS trigger AS
$$
declare
v_upd_string text;
v_sqlstate text;
v_message text;
v_context text;
BEGIN
v_upd_string := 'UPDATE ' || TG_TABLE_SCHEMA || '.' || TG_TABLE_NAME;
IF (TG_OP = 'INSERT') THEN
v_upd_string := v_upd_string || ' SET create_timestamp = ''' || now() || ''', ';
v_upd_string := v_upd_string || ' update_timestamp = ''' || now() || ''' where syspk = ' || new.syspk;
ELSEIF (TG_OP = 'UPDATE') THEN
v_upd_string := v_upd_string || ' SET update_timestamp = ''' || now() || ''' where syspk = ' || old.syspk;
END IF;
execute (v_upd_string);
RETURN new;
EXCEPTION WHEN OTHERS THEN
GET STACKED DIAGNOSTICS
v_sqlstate = returned_sqlstate,
v_message = message_text,
v_context = pg_exception_context;
RETURN NULL;
END
$$ LANGUAGE plpgsql;