sql >> Database teknologi >  >> RDS >> Oracle

PLSQL :NY og :GAMMEL

Du bruger normalt termerne i en trigger ved hjælp af :old for at referere til den gamle værdi og :new for at referere til den nye værdi.

Her er et eksempel fra Oracle-dokumentationen, der er linket til ovenfor

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;

I dette eksempel udløses udløseren BEFORE DELETE OR INSERT OR UPDATE :old.sal vil indeholde lønnen før triggerudløsningen og :new.sal vil indeholde den nye værdi.



  1. 'IF' i 'SELECT'-sætning - vælg outputværdi baseret på kolonneværdier

  2. INSERT INTO @TABLE EXEC @query med SQL Server 2000

  3. MySQL-strengfunktioner (fuld liste)

  4. Hvordan ændrer du datatypen for en kolonne i SQL Server?