在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;
/
這些示例都是在插入新記錄后觸發的觸發器,并根據新插入記錄的某個列值執行不同的操作。你可以根據自己的需求修改觸發器和條件語句。