DML錯誤日志是oracle10gR2引入的一個類似於SQL*Loader的錯誤日志功能。它的基本原理是把任何可能導致語句失敗的記錄轉移,放到一張錯誤日志表中。
具體使用如下:
1、使用DBMS_ERRLOG.CREATE_ERROR_LOG來創建錯誤日志表
--原表my_test表結構 desc my_test Name Type Nullable Default Comments ------ ------------ -------- ------- -------- SID NUMBER NAME VARCHAR2(20) Y GENDER INTEGER Y AGE NUMBER Y HOBBY VARCHAR2(20) Y --執行下面的語句,生成錯誤日志表 execute dbms_errlog.create_error_log('my_test','my_test_bad'); PL/SQL procedure successfully completed. --生成的錯誤日志表my_test_bad結構 desc my_test_bad Name Type Nullable Default Comments --------------- -------------- -------- ------- -------- ORA_ERR_NUMBER$ NUMBER Y ORA_ERR_MESG$ VARCHAR2(2000) Y ORA_ERR_ROWID$ UROWID(4000) Y ORA_ERR_OPTYP$ VARCHAR2(2) Y ORA_ERR_TAG$ VARCHAR2(2000) Y SID VARCHAR2(4000) Y NAME VARCHAR2(4000) Y GENDER VARCHAR2(4000) Y AGE VARCHAR2(4000) Y HOBBY VARCHAR2(4000) Y
其中ORA_ERR_TAG$這個字段可以存放用戶自定義的數據
2、在insert語句中使用my_test_bad錯誤日志表
insert into my_test (sid,name,gender,age,hobby) values (12,'joy',2,'age','book,football,run') log errors into my_test_bad; insert into my_test (sid,name,gender,age,hobby) values (12,'joy',2,'age','book,football,run') log errors into my_test_bad ORA-01722: 無效數字 SQL> select * from my_test_bad;--(結果不規范,用圖展示)
update,delete,merge語句都可以在後面聲明錯誤日志,方法相同。如:
update my_test set age = 'yyy' where sid = 12 log errors into my_test_bad;
注意事項:log errors子句不引起隱式提交,也就是說,即使回滾了失誤,錯誤信息還是會保存在錯誤日志表中。