Skip site navigation (1) Skip section navigation (2)

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 (view raw or flat)
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

pgsql-sql by date

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

Privacy Policy | About PostgreSQL
Copyright © 1996-2014 The PostgreSQL Global Development Group