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

Reply via email to