Oracle DML錯誤記錄檔筆記
DML錯誤記錄檔是Oracle 10gR2引入的一個類似於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子句不引起隱式提交,也就是說,即使復原了失誤,錯誤資訊還是會儲存在錯誤記錄檔表中。