在Oracle触发器中,DECLARE
关键字用于声明局部变量、常量、游标、异常等。这些声明需要在触发器的BEGIN...END
块之前进行。以下是一个简单的示例,展示了如何在Oracle触发器中使用DECLARE
声明局部变量和游标:
CREATE OR REPLACE TRIGGER my_trigger AFTER INSERT ON my_table FOR EACH ROW DECLARE v_new_id NUMBER; CURSOR c_my_data IS SELECT id, name FROM my_table WHERE id = :new.id; BEGIN -- 声明局部变量 v_new_id := :new.id; -- 打开游标 OPEN c_my_data; -- 获取游标中的数据 LOOP FETCH c_my_data INTO v_id, v_name; EXIT WHEN c_my_data%NOTFOUND; -- 处理游标中的数据 DBMS_OUTPUT.PUT_LINE('ID: ' || v_id || ', Name: ' || v_name); END LOOP; -- 关闭游标 CLOSE c_my_data; EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE('Error: ' || SQLERRM); END; /
在这个示例中,我们创建了一个名为my_trigger
的触发器,它在插入新记录到my_table
表后执行。在触发器的DECLARE
块中,我们声明了一个名为v_new_id
的局部变量和一个名为c_my_data
的游标。然后,在BEGIN
块中,我们使用:new.id
获取插入的新记录的ID,并将其赋值给v_new_id
。接下来,我们打开游标c_my_data
,并使用LOOP
循环遍历游标中的数据,将它们输出到控制台。最后,我们在EXCEPTION
块中处理可能发生的异常。