sql >> Databáze >  >> RDS >> Oracle

PLSQL :NOVÉ a :STARÉ

Termíny běžně používáte ve spouštěči pomocí :old odkazovat na starou hodnotu a :new odkazovat na novou hodnotu.

Zde je příklad z dokumentace Oracle propojené výše

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;

V tomto příkladu se pravidlo spustí BEFORE DELETE OR INSERT OR UPDATE :old.sal bude obsahovat plat před odpálením spouště a :new.sal bude obsahovat novou hodnotu.



  1. Zaznamenejte změny záznamu na serveru SQL do auditní tabulky

  2. Syntaxe SQL UPDATE – Zobrazeno podle DBMS

  3. Jak vložit zalomení řádku do řetězce SQL Server VARCHAR/NVARCHAR

  4. Můj DBA je nemocný – Tipy pro přepnutí databáze při selhání databáze pro správce systému