This Oracle tutorial explains how to create a BEFORE UPDATE Trigger in Oracle with syntax and examples.
A BEFORE UPDATE Trigger means that Oracle will fire this trigger before the UPDATE operation is executed.
The syntax to create a BEFORE UPDATE Trigger in Oracle/PLSQL is:
CREATE [ OR REPLACE ] TRIGGER <strong>trigger_name</strong>
BEFORE UPDATE
ON <strong>table_name</strong>
[ FOR EACH ROW ]
DECLARE
-- variable declarations
BEGIN
-- trigger code
EXCEPTION
WHEN ...
-- exception handling
END;
Optional. If specified, it allows you to re-create the trigger is it already exists so that you can change the trigger definition without issuing a drop a trigger statement.
The name of the trigger to create.
It indicates that the trigger will fire before the UPDATE operation is executed.
The name of the table that the trigger is created on.
Let's look at an example of how to create an BEFORE UPDATE trigger using the CREATE TRIGGER statement.
If you had a table created as follows:
CREATE TABLE orders
( order_id number(5),
quantity number(4),
cost_per_item number(6,2),
total_cost number(8,2),
updated_date date,
updated_by varchar2(10)
);
We could then use the CREATE TRIGGER statement to create an BEFORE UPDATE trigger as follows:
CREATE OR REPLACE TRIGGER orders_before_update
BEFORE UPDATE
ON orders
FOR EACH ROW
DECLARE
v_username varchar2(10);
BEGIN
-- Find username of person performing UPDATE on the table
SELECT user INTO v_username
FROM dual;
-- Update updated_date field to current system date
:new.updated_date := sysdate;
-- Update updated_by field to the username of the person performing the UPDATE
:new.updated_by := v_username;
END;
/