Un trigger definisce una funzione che agisce prima o dopo un’altra azione su una tabella.
In sostanza un trigger richiama una determinata funzione (che deve essere creata a priori) che esegue operazioni sui valori di una tabella.
Nel caso particolare di questo esempio disponiamo di una tabella chiamata “valori” che contiene 5 colonne:
valore1, valore2, valore3, valore4 e somma (tutti di tipo integer).
I valori delle prime 4 colonne vengono inserite dall’utente; vogliamo fare in modo che la quinta colonna (somma) venga popolata dalla funzione richiamata dal trigger una volta che i primi 4 valori sono inseriti. Procediamo:
– definiamo la funzione:
nome_db=> CREATE OR REPLACE FUNCTION somma_valori() RETURNS trigger AS $somma_valori$ DECLARE new_somma integer;
BEGIN IF (TG_OP=’INSERT’) THEN UPDATE valori SET somma=valore1+valore2+valore3+valore4; END IF; RETURN NEW; END; $somma_valori$ language plpgsql;
– definiamo ora il trigger che richiama la funzione ad ogni INSERT che avviene nella tabella;
nome_db=> CREATE TRIGGER tr_somma_valori AFTER INSERT ON valori FOR EACH ROW EXECUTE PROCEDURE somma_valori();
In questo modo ogni volta che vengono inseriti i primi 4 valori vedremo popolarsi automagicamente anche il quinto.
Ottima spiegazione, bravo Flavio!