22/11/2010, 13:08
|
| | Fecha de Ingreso: noviembre-2010
Mensajes: 3
Antigüedad: 14 años, 2 meses Puntos: 0 | |
Como hacer una funcion que actualice un atributo de una tabla, sin crear un trigger ? Hola, perdonen las molestias pero no sé como resolver este problema.
Tengo una tabla llamada unidades_venta donde su esquema es:
REATE TEMP TABLE unidad_venta (
Codigo_Producto char(10),
Num_Serie int8,
Fecha_Adquisicion date NOT NULL DEFAULT current_date,
Precio_Salida numeric(8,2) DEFAULT 0 NOT NULL CHECK (Precio_Salida > 0),
Precio_Actual numeric(8,2) DEFAULT 0 NOT NULL CHECK (Precio_Actual >= 0),
CONSTRAINT FK_comp2 PRIMARY KEY (Codigo_Producto, Num_Serie)
);
Lo que quiero realizar es un procedimiento que actualice el precio_actual de venta (ya esablecido) de las unidades en función de la fecha de su adquisición . Si ésta es mayor que 395 días, o sea, un año y un mes: este precio irá bajando un 5% cada mes. Para centralizar el proceso de actualización será el usuario quien invocará este proceso el primer día de cada mes y modificara el precio actual de las unidades cada vez a un 5% menos.
Mi problema está en que no se como hacer en el RETURN para que me devuelva la función en el atributo 'precio_actual' de mi tabla unidades_venta. Aquí les dejo lo que he intentado hacer sin éxito. Quiero que no llame a un TRIGGER, sino que se ejecute el procedimiento cada vez que yo invoque la función, pero no cuando haga un INSERT OR UPDATE. La cuestión sería cambiar lo que he hecho de modo que haga lo que pido sin llamar a un RETURNS TRIGGER.
CREATE OR REPLACE FUNCTION precioventa() RETURNS TRIGGER AS'
DECLARE
productos unidad_venta%ROWTYPE;
BEGIN
SELECT * INTO productos from unidad_venta where fecha_adquisicion + 395 < current_date;
IF FOUND THEN
UPDATE unidad_venta SET precio_actual = precio_actual - ((precio_actual*5)/100);
RETURN NEW;
ELSE
UPDATE unidad_venta SET precio_actual = precio_actual;
RETURN NEW;
END IF;
END;
'LANGUAGE 'plpgsql';
Espero que me puedan ayudar. Gracias |