[Oracle] 利用自治事务实现审计功能
2015-08-04 14:07
549 查看
[Oracle] 利用自治事务实现审计功能
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 as
BEGIN
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 p1
PL/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 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12
相关文章推荐
- 在Oracle中使用Guid
- Oracle学习之DATAGUARD(三) 使用11gRMAN新特性搭建standby
- oracle数据库高级应用之《触发器的建立》
- oracle 记录被另一个用户锁住
- Oracle 多字段的in
- Oracle中定时作业(Job)使用方法详解
- oracle之sql语句优化
- oracle、mysql、sqlserver分组拼接
- oracle select语句
- 在往oracle中插数据时,如何处理excel读取的时间空值
- Oracle 创建索引的基本规则总结
- Oracle中的视图理解
- 重启linux下的oracle数据库
- oracle删掉重复数据的语法
- Oracle启动报错ORA-27102解决
- 【转】一个非常标准的Java连接Oracle数据库的示例代码
- oracle case where 复杂sql语句
- GROUPING SETS、ROLLUP、CUBE
- ORACLE RAC工作原理
- oracle database 11g 架构图