Oracle
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Oracle

ghi nhật ký chèn / cập nhật / xóa trong cơ sở dữ liệu oracle

Bạn có thể tìm thấy nhiều ví dụ về trình kích hoạt trong tài liệu Oracle. Những gì bạn cần là sau khi chèn, cập nhật, xóa cho từng hàng kích hoạt để điền các bảng nhật ký của bạn. Dưới đây là một số ví dụ từ tài liệu Oracle:

http://docs.oracle.com/cd /B28359_01/appdev.111/b28370/triggers.htm#LNPLS020

CREATE TABLE Emp_log (
  Emp_id     NUMBER,
  Log_date   DATE,
  New_salary NUMBER,
  Action     VARCHAR2(20));

 CREATE OR REPLACE TRIGGER Log_salary_increase_ARUID
  AFTER UPDATE OR INSERT OR DELETE ON emp
  FOR EACH ROW
BEGIN
  -- Can be separated for Inserting then Updating with addl if
  -- In this case it may be easier to control and/or add flags to your log tables
  -- such as Action = 'INS' or Action = 'UPD' --
  If (INSERTING OR UPDATING) 
  THEN
    -- Insert newly created/updated values to your log table --
    INSERT INTO Emp_log (Emp_id, Log_date, New_salary, Action)
     VALUES (:NEW.Empno, SYSDATE, :NEW.SAL, 'INS_UPD');
  ELSE  
    -- Deleting - insert old or deleted values to your logs --
   INSERT INTO Emp_log (Emp_id, Log_date, New_salary, Action)
     VALUES (:OLD.Empno, SYSDATE, :OLD.SAL, 'DEL');
END;
/


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Các câu hỏi hàng đầu về JAVA / JRE trong Ứng dụng Oracle

  2. Tạo chuỗi Oracle bắt đầu bằng chữ và số

  3. Trong Oracle SQL:Làm cách nào để bạn chèn ngày + giờ hiện tại vào bảng?

  4. VARCHAR (MAX) so với VARCHAR (n) trong Oracle

  5. Chèn vào hai bảng tiên tri với một chuỗi