Oracle
 sql >> Base de données >  >> RDS >> Oracle

PLSQL :NOUVEAU et :ANCIEN

Vous utilisez normalement les termes dans un déclencheur en utilisant :old pour référencer l'ancienne valeur et :new pour référencer la nouvelle valeur.

Voici un exemple de la documentation Oracle liée à ci-dessus

CREATE OR REPLACE TRIGGER Print_salary_changes
  BEFORE DELETE OR INSERT OR UPDATE ON Emp_tab
  FOR EACH ROW
WHEN (new.Empno > 0)
DECLARE
    sal_diff number;
BEGIN
    sal_diff  := :new.sal  - :old.sal;
    dbms_output.put('Old salary: ' || :old.sal);
    dbms_output.put('  New salary: ' || :new.sal);
    dbms_output.put_line('  Difference ' || sal_diff);
END;

Dans cet exemple, le déclencheur déclenche BEFORE DELETE OR INSERT OR UPDATE :old.sal contiendra le salaire avant le déclenchement du déclencheur et :new.sal contiendra la nouvelle valeur.