Skip site navigation (1) Skip section navigation (2)

Peripheral Links

Header And Logo

PostgreSQL
| The world's most advanced open source database.

Site Navigation

Search for
  Advanced Search

Advice for generalizing trigger functions



I've created quite a few functions that log modifications to various history tables. (the history table has the same name as the base table but is prefixed by the 'History.' schema.) The only difference between functions I can find is the table name.

Is there any way to generalize these myriad of functions into one?


Below is a sample of a typical logging trigger function.

Regards,
Richard Broersma Jr.


CREATE OR REPLACE FUNCTION "project"."log_managers_ops"()
RETURNS trigger AS
$BODY$
BEGIN


     IF TG_OP IN ( 'UPDATE', 'DELETE' ) THEN
     
          UPDATE History.Managers AS M
             SET endts = now()
           WHERE M.manager_id = OLD.manager_id
             AND now() BETWEEN M.startts AND M.endts;
             
     end IF;
     
     
     IF TG_OP IN ( 'UPDATE', 'INSERT' ) THEN
     
     INSERT INTO History.Managers
          VALUES ( now()::timestamptz, 'INFINITY'::timestamptz, NEW.*);

          RETURN NEW;
          
     END IF;

     RETURN OLD;

END;
$BODY$
LANGUAGE 'plpgsql' VOLATILE SECURITY DEFINER;




Home | Main Index | Thread Index

Privacy Policy | PostgreSQL Archives hosted by Command Prompt, Inc. | Designed by tinysofa
Copyright © 1996 – 2008 PostgreSQL Global Development Group