[Oracle] 利用自治事务实现审计功能
来源:互联网 发布:帝国cms官方网站 编辑:程序博客网 时间:2024/06/07 13:02
在一个事务(外层事务)中可以定义一个或几个自治事务。自治事务可以独立commit,不对外层事务产生影响,同样外层事务的 rollback 也对自治事务没有影响。
假设现在有这样一个需求,不能对某个表进行某些操作(如更新),一旦有这类操作,就强制整个回滚,并且在审计日志中记录该次违规操作。现在的问题是当事务回滚之后,日志中的记录也会跟着被回滚,这时就可以利用自治事务来防止这个问题。
首先,定义日志表,用于审计。
create table error_logs( id number(10) not null, log_timestamp timestamp not null, error_message varchar2(4000));create sequence error_log_seq;
创建一个自治事务的存储过程(关键字PRAGMA AUTONOMOUS_TRANSACTION代表自治事务),用于向审计表插入错误信息
create or replace procedure log_errors(p_error_message IN varchar2) as PRAGMA AUTONOMOUS_TRANSACTION;BEGIN insert into error_logs (id, log_timestamp, error_message) values (error_log_seq.NEXTVAL, systimestamp, p_error_message); commit;END;/
创建一个测试表,定义该表的ID字段不为空
create table at_test( id number(10) not null, des varchar2(200));
定义一个存储过程,尝试向测试表中插入非法数据
create or replace procedure p1 asBEGIN insert into at_test (id, des) values (1, 'desc1'); insert into at_test (id, des) values (NULL, 'desc2');EXCEPTION WHEN OTHERS THEN log_errors (p_error_message => SQLERRM); rollback;END;/
执行这个存储过程,查看是否审计成功
SQL> exec p1PL/SQL 过程已成功完成。SQL> select * from at_test;未选定行SQL> select * from error_logs; ID LOG_TIMESTAMP ERROR_MESSAGE---------- -------------------------------- ------------------------------------------------------- 2 28-5月 -13 03.34.51.210000 下午 ORA-01400: 无法将 NULL 插入 ("TEST"."AT_TEST"."ID")
从上面的结果可以发现,向at_test表插入数据的事务正常回滚,而审计自治事务不回滚。
- [Oracle] 利用自治事务实现审计功能
- [Oracle] 利用自治事务实现审计功能
- 利用自治事务技术写一个用于审计的触发器
- Oracle的自治事务
- Oracle自治事务读书笔记
- Oracle自治事务介绍
- ORACLE中的自治事务
- Oracle的自治事务
- Oracle-自治事务
- 了解oracle自治事务
- Oracle自治事务
- Oracle自治事务介绍
- Oracle自治事务
- Oracle自治事务
- oracle 自治事务
- oracle 自治事务
- 了解oracle自治事务
- oracle自治事务
- android获取web服务器端session并验证登陆 一
- yum安装lamp环境
- Merge Sorted Array
- VS2010 调试经验总结
- printk
- [Oracle] 利用自治事务实现审计功能
- CKEditor
- hdu 1069 Monkey and Banana
- android ListView实现颜色交替并且有点击效果
- 移动通信知识之GSM
- 无法找到调试信息,或者调试信息不匹配,cannot find or open the pdb file
- RMI For C++(RCF 1.0)
- Pomelo:网易开源基于 Node.js 的游戏服务端框架
- ireport5.0图形报表--柱状图