From: | Miguel Rodríguez Penabad <penabad(at)gmail(dot)com> |
---|---|
To: | pgsql-es-ayuda(at)postgresql(dot)org |
Subject: | Re: pregunta sobre trigger |
Date: | 2007-11-02 08:53:23 |
Message-ID: | 95335e4e0711020153m52dbab5frde3a1d2184d6e32b@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-es-ayuda |
> > - La cosa es que quiero un trigger que cuando yo llame la siguiente sentencia: DELETE FROM PERSONA WHERE Idpersona=1
> > en lugar de eliminar la persona indicada, lo que haga sea actualizar el campo activo al valor 0, es decir UPDATE.
>[Mario Jiménez Carrasco <mario(dot)carrasco(at)gmail(dot)com>]
> ¿Y por qué no hacer UPDATE directamente ?... digo, hacer solo un paso en
> vez de dos...
Aparte de coincidir con la pregunta de Mario....
Puedes resolverlo con una regla (rule) o con una función+trigger:
Ahí te va un ejemplo. Por cierto, ya que tenemos el tipo boolean, yo
no usaría el truco-chapuza-workaround-como_quieras_llamarlo de usar un
entero para eso.
create table persona(idpersona serial, nombre text, activo boolean);
CREATE RULE DELETE_A_UPDATE
AS ON DELETE
TO persona
DO INSTEAD
UPDATE persona SET ACTIVO = false
WHERE idpersona = OLD.idpersona;
Alternativa con un trigger:
Primero creamos la función
CREATE OR REPLACE FUNCTION borrado_a_modif()
RETURNS TRIGGER LANGUAGE plpgsql AS $$
BEGIN
UPDATE persona SET activo=false WHERE idpersona=OLD.idpersona;
RETURN NULL; -- importante! esto EVITA el delete
END
$$;
Y luego el trigger: DEBE ser BEFORE DELETE y FOR EACH ROW para que se pueda
evitar el borrado.
CREATE TRIGGER desactiva_no_borres
BEFORE DELETE ON persona FOR EACH ROW
EXECUTE PROCEDURE borrado_a_modif();
Saludos
--
Miguel Rodríguez Penabad
From | Date | Subject | |
---|---|---|---|
Next Message | Conxita Marín | 2007-11-02 10:36:43 | Re: [pgsql-es-ayuda] Función que escriba en letras una cantidad numérica |
Previous Message | Jenaro Centeno Gomez | 2007-11-02 00:33:54 | Re: hora del servidor |