mysql dml 日志_Oracle DML错误日志笔记
DML錯誤日志是Oracle 10gR2引入的一個類似于SQL*Loader的錯誤日志功能。它的基本原理是把任何可能導致語句失敗的記錄轉移,放到一
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子句不引起隱式提交,也就是說,即使回滾了失誤,錯誤信息還是會保存在錯誤日志表中。
本文永久更新鏈接地址:,
本文原創發布php中文網,轉載請注明出處,感謝您的尊重!
總結
以上是生活随笔為你收集整理的mysql dml 日志_Oracle DML错误日志笔记的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql数据库设计的原则_MySQL数
- 下一篇: python发送邮件拒绝_人生苦短之Py