RE: Actualizar campos que tienen dependencias Foreign Key

From: José Fermín Francisco Ferreras <josefermin54(at)hotmail(dot)com>
To: <jcmedinanix(at)gmail(dot)com>, Lista PostgreSQL <pgsql-es-ayuda(at)postgresql(dot)org>
Subject: RE: Actualizar campos que tienen dependencias Foreign Key
Date: 2010-01-25 14:35:06
Message-ID: COL103-W213964733D3A87A7382EF3C65F0@phx.gbl
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-es-ayuda

ing. José Fermín Francisco Ferreras
San Francisco de Macorís, Rep. Dom.

Date: Mon, 25 Jan 2010 08:42:06 -0500
Subject: [pgsql-es-ayuda] Actualizar campos que tienen dependencias Foreign Key
From: jcmedinanix(at)gmail(dot)com
To: pgsql-es-ayuda(at)postgresql(dot)org

>saludos una consulta. Quiero borrar de una tabla llamada productos un producto(cuando digo >borrar me refiero a actualizar su estado de true a false). Pero resulta que este producto tiene >muchas dependencias es llamado or otras tablas. Como dar de baja a ese producto haciendo >que todas las dependencias pasen de true a false. Atraves de un trigger(maneja potsgres >triggers). Porque el update on cascade no me serviria en este caso ya que no estoy actualizando >el id si no un campo diferente a este todas las tablas manejan campo estado el cual es true si >esta activo y false si esta eliminado. Gracias por su colaboracion de antemano.

Podrias probar esto, lo hice medio rapido, si tiene errores tendrias q corregirlo, pero creo va por donde quieres.

CREATE OR REPLACE FUNCTION esquema.cambiar_status()
RETURNS trigger
LANGUAGE plpgsql
AS $function$
begin
UPDATE tabla SET
campo = false
where codigo=new.codigo;
return new;
end;
$function$


_________________________________________________________________

In response to

Responses

Browse pgsql-es-ayuda by date

  From Date Subject
Next Message Juan Carlos Medina Ruiz 2010-01-25 14:48:37 Re: Actualizar campos que tienen dependencias Foreign Key
Previous Message Edwin Quijada 2010-01-25 13:48:19 RE: Que puede envidiar postgresql a oracle ?