在Oracle触发器中使用条件语句,你可以使用IF
、CASE
或WHEN
等关键字
IF
语句:CREATE OR REPLACE TRIGGER example_trigger
AFTER INSERT ON example_table
FOR EACH ROW
DECLARE
v_new_value NUMBER;
BEGIN
v_new_value := :NEW.column_name;
IF v_new_value > 10 THEN
-- 执行某个操作
DBMS_OUTPUT.PUT_LINE('新值大于10');
ELSEIF v_new_value <= 10 AND v_new_value > 0 THEN
-- 执行另一个操作
DBMS_OUTPUT.PUT_LINE('新值在0和10之间');
ELSE
-- 执行其他操作
DBMS_OUTPUT.PUT_LINE('新值小于等于0');
END IF;
END;
/
CASE
语句:CREATE OR REPLACE TRIGGER example_trigger
AFTER INSERT ON example_table
FOR EACH ROW
DECLARE
v_new_value NUMBER;
BEGIN
v_new_value := :NEW.column_name;
CASE
WHEN v_new_value > 10 THEN
-- 执行某个操作
DBMS_OUTPUT.PUT_LINE('新值大于10');
WHEN v_new_value <= 10 AND v_new_value > 0 THEN
-- 执行另一个操作
DBMS_OUTPUT.PUT_LINE('新值在0和10之间');
ELSE
-- 执行其他操作
DBMS_OUTPUT.PUT_LINE('新值小于等于0');
END CASE;
END;
/
WHEN
语句:CREATE OR REPLACE TRIGGER example_trigger
AFTER INSERT ON example_table
FOR EACH ROW
DECLARE
v_new_value NUMBER;
BEGIN
v_new_value := :NEW.column_name;
WHEN v_new_value > 10 THEN
-- 执行某个操作
DBMS_OUTPUT.PUT_LINE('新值大于10');
WHEN v_new_value <= 10 AND v_new_value > 0 THEN
-- 执行另一个操作
DBMS_OUTPUT.PUT_LINE('新值在0和10之间');
ELSE
-- 执行其他操作
DBMS_OUTPUT.PUT_LINE('新值小于等于0');
END WHEN;
END;
/
这些示例都是在插入新记录后触发的触发器,并根据新插入记录的某个列值执行不同的操作。你可以根据自己的需求修改触发器和条件语句。