PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Precisa de ajuda com um gatilho e função do Postgres


Pode funcionar assim:
CREATE OR REPLACE FUNCTION public.f_brand_lookup()
   RETURNS trigger AS
$func$
BEGIN
   SELECT INTO NEW.brand
          bt.brand
   FROM   brand_translation bt
   WHERE  bt.source = NEW.source;

   RETURN NEW;
END
$func$
LANGUAGE plpgsql;

CREATE TRIGGER brand_insert_before_lookup
BEFORE INSERT ON subscriber
FOR EACH ROW EXECUTE PROCEDURE public.f_brand_lookup();

Há muita coisa completamente errada com seu exemplo.
Você precisa começar estudando o básico. Como sempre, sugiro o manual muito bom.
Comece aqui e aqui .