I am creating a trigger in Postgresql as follows.
CREATE TRIGGER "PRODUCT_ADD_TRIGGER" AFTER INSERT
ON product FOR EACH ROW
EXECUTE PROCEDURE INVENTORY_ENTRY_NEW_PRODUCT(NEW.productcode);
COMMENT ON TRIGGER "PRODUCT_ADD_TRIGGER" ON product
IS '-- Executes a procedure that inserts a row into the inventorytxns table.';
When executed in the Query Manager of pgAdmin-III, the following error is thrown.
ERROR: syntax error at or near "."
LINE 3: ... EXECUTE PROCEDURE INVENTORY_ENTRY_NEW_PRODUCT(NEW.productco...
^
********** Error **********
ERROR: syntax error at or near "."
SQL state: 42601
Character: 130
Can anyone tell me what is wrong with my code. I've searched everywhere.
EDIT : Code for the procedure that is to be executed. This procedure has been successfully added to the database.
-- Function: "INVENTORY_ENTRY_NEW_PRODUCT"(integer)
-- DROP FUNCTION "INVENTORY_ENTRY_NEW_PRODUCT"(integer);
CREATE OR REPLACE FUNCTION "INVENTORY_ENTRY_NEW_PRODUCT"(productcode integer)
RETURNS record AS
$BODY$
-- Declare the required variables.
DECLARE
-- Inventory row that stores the result of the query on the inventory table.
inventoryrow inventory%ROWTYPE;
result record;
BEGIN
SELECT * INTO inventoryrow from inventory where fk_productcode = productcode;
IF NOT FOUND THEN
-- INVENTORY TRANSACTION CAN BE ADDED.
-- An inventory transaction can be added to the inventorytxns table
INSERT INTO inventorytxns (fk_productcode,fk_txntypeid) VALUES(productcode,6);
-- Once a row is added into the inventory txns table, it automatically adds data into the inventory table.
SELECT * INTO result FROM INVENTORY WHERE fk_productcode = productcode;
IF NOT FOUND THEN
-- RAISE AN EXCEPTION. THIS OPERATION IS SUPPOSED TO HAPPEN.
RAISE EXCEPTION 'Product with product code % added in inventorytxns table but not added in inventory table',productcode;
END IF;
-- Transaction type 6 represents addition of a new product transaction type.
END IF;
RAISE DEBUG 'Product with product code % already available in inventory',productcode;
END;
-- Check if the inventory entry already exits in the inventory table.
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100;
ALTER FUNCTION "INVENTORY_ENTRY_NEW_PRODUCT"(integer)
OWNER TO postgres;
COMMENT ON FUNCTION "INVENTORY_ENTRY_NEW_PRODUCT"(integer) IS 'Adds a new entry in the inventorytxns table for a new product.';