如何创建触发器以使用更新语句调用过程
How to create a trigger to call the procedure with an update statement
我需要编写程序和更新触发器。当对 table 进行任何更新时,触发器应该调用该过程。程序应更新另一个 table 中的更改。在另一个 table 旧值中,更新值应该在那里。
您所描述的听起来像是普通日志记录;您真的不需要程序,触发器可以完成所有工作。这是一个例子:
SQL> create table emp_log (empno number, sal_old number, sal_new number);
Table created.
SQL> create or replace trigger trg_bu_emp
2 before update of sal on emp
3 for each row
4 begin
5 insert into emp_log (empno, sal_old, sal_new)
6 values
7 (:new.empno, :old.sal, :new.sal);
8 end;
9 /
Trigger created.
SQL> select empno, ename, sal from emp where ename = 'KING';
EMPNO ENAME SAL
---------- ---------- ----------
7839 KING 5000
SQL> update emp set sal = 7000 where ename = 'KING';
1 row updated.
SQL> select * from emp_log;
EMPNO SAL_OLD SAL_NEW
---------- ---------- ----------
7839 5000 7000
SQL>
[编辑,阅读评论后]
家庭作业,嗯?所以 - 创建一个过程:
SQL> rollback;
Rollback complete.
SQL> create or replace procedure p_emp_sal_log
2 (par_empno in emp.empno%type, par_sal_old in emp.sal%type,
3 par_sal_new in emp.sal%type)
4 is
5 begin
6 insert into emp_log (empno, sal_old, sal_new)
7 values
8 (par_empno, par_sal_old, par_sal_new);
9 end;
10 /
Procedure created.
SQL> create or replace trigger trg_bu_emp
2 before update of sal on emp
3 for each row
4 begin
5 p_emp_sal_log(:new.empno, :old.sal, :new.sal);
6 end;
7 /
Trigger created.
SQL> update emp set sal = 2000 where ename = 'KING';
1 row updated.
SQL> select * from emp_log;
EMPNO SAL_OLD SAL_NEW
---------- ---------- ----------
7839 5000 2000
SQL>
我需要编写程序和更新触发器。当对 table 进行任何更新时,触发器应该调用该过程。程序应更新另一个 table 中的更改。在另一个 table 旧值中,更新值应该在那里。
您所描述的听起来像是普通日志记录;您真的不需要程序,触发器可以完成所有工作。这是一个例子:
SQL> create table emp_log (empno number, sal_old number, sal_new number);
Table created.
SQL> create or replace trigger trg_bu_emp
2 before update of sal on emp
3 for each row
4 begin
5 insert into emp_log (empno, sal_old, sal_new)
6 values
7 (:new.empno, :old.sal, :new.sal);
8 end;
9 /
Trigger created.
SQL> select empno, ename, sal from emp where ename = 'KING';
EMPNO ENAME SAL
---------- ---------- ----------
7839 KING 5000
SQL> update emp set sal = 7000 where ename = 'KING';
1 row updated.
SQL> select * from emp_log;
EMPNO SAL_OLD SAL_NEW
---------- ---------- ----------
7839 5000 7000
SQL>
[编辑,阅读评论后]
家庭作业,嗯?所以 - 创建一个过程:
SQL> rollback;
Rollback complete.
SQL> create or replace procedure p_emp_sal_log
2 (par_empno in emp.empno%type, par_sal_old in emp.sal%type,
3 par_sal_new in emp.sal%type)
4 is
5 begin
6 insert into emp_log (empno, sal_old, sal_new)
7 values
8 (par_empno, par_sal_old, par_sal_new);
9 end;
10 /
Procedure created.
SQL> create or replace trigger trg_bu_emp
2 before update of sal on emp
3 for each row
4 begin
5 p_emp_sal_log(:new.empno, :old.sal, :new.sal);
6 end;
7 /
Trigger created.
SQL> update emp set sal = 2000 where ename = 'KING';
1 row updated.
SQL> select * from emp_log;
EMPNO SAL_OLD SAL_NEW
---------- ---------- ----------
7839 5000 2000
SQL>