trigger needs to check in multiple tables.

From: Jacobo García <jacobo(dot)garcia(at)gmail(dot)com>
To: pgsql-sql(at)postgresql(dot)org
Subject: trigger needs to check in multiple tables.
Date: 2006-08-18 17:17:27
Message-ID: 5f867bd20608181017u2ccf8db7o12338bbbe66977fb@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Hello.

I'm running a simple query inside a function that is associated with a
trigger:

SELECT tipo INTO tipocuenta FROM producto WHERE codigo_cuenta=
NEW.codigo_destino;

I am getting this error when running the code on pgadmin III

ERROR: NEW used in query that is not in a rule
QUERY: SELECT tipo FROM producto WHERE codigo_cuenta=NEW.codigo_destino

I don't know what is failing. I'm running postgresql 8.1.4 on windows. Maybe
I have to enable something?

Here is the complete code of the function, sure there will be things wrong,
but the statement failing is just next to BEGIN

CREATE OR REPLACE FUNCTION movimientosenoficina()
RETURNS BOOLEAN AS $$

DECLARE

esoficinacorrecta BOOLEAN;
esfechacorrecta BOOLEAN;
op INTEGER;
fondo INTEGER;
imp INTEGER;
tipocuenta INTEGER;

BEGIN

SELECT tipo INTO tipocuenta FROM producto WHERE codigo_cuenta=
NEW.codigo_destino;

IF (tipocuenta=71) THEN

IF (op=51) THEN
esfechacorrecta:=primerosmes();
esoficinacorrecta:=oficinacorrecta(NEW.codigo,NEW.codigo_oficina
);

ELSIF (NOT op=11 OR NOT op=12)

RAISE EXCEPTION 'Operación no permitida sobre cuentas a plazo';

END IF;

ELSIF (tipocuenta=60)

--Permiten todo tipo de operaciones

ELSIF (tipocuenta=10)

IF (op=54) THEN

SELECT saldo INTO fondo FROM producto WHERE codigo_cuenta =
NEW.destino;
SELECT cantidad INT imp FROM movimiento WHERE codigo =
NEW.codigo;

IF (fondo!=imp) THEN

RAISE EXCEPTION 'Se ha de transferir todo el saldo de la
cuenta'

ELSE
oficinacorrecta(NEW.codigo,NEW.codigo_oficina);

-- Ponemos la cuenta inactiva si retiramos los fondos
UPDATE cuenta_a_plazo SET activo=TRUE WHERE codigo_cuenta =
NEW.destino;
ENDIF;
ENDIF;

ELSE
RAISE EXCEPTION 'Tipo de cuenta no existente';

END IF;

RETURN NEW;

END;
$$ LANGUAGE plpgsql;

/* Este trigger se activa una vez hemos comenzado la transaccion y hemos
insertado en movimiento_oficina
nos sirve para evitar operaciones no definidas o erroneas sobre los
distintos tipos de cuentas*/

CREATE TRIGGER validamovimientosenoficina BEFORE INSERT OR UPDATE ON CLIENTE
FOR EACH ROW EXECUTE PROCEDURE movimientosenoficina();

--
Jacobo García López de Araujo

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Michael Fuhr 2006-08-19 01:01:21 Re: trigger needs to check in multiple tables.
Previous Message Andrew Sullivan 2006-08-18 15:20:19 Re: Multiple DB join