[Oracle] 利用自治事务实现审计功能

php中文网
发布: 2016-06-07 17:29:30
原创
1269人浏览过

在一个事务(外层事务)中可以定义一个或几个自治事务。自治事务可以独立commit,不对外层事务产生影响,同样外层事务的 rollback

在一个事务(外层事务)中可以定义一个或几个自治事务。自治事务可以独立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 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;
/

执行这个存储过程,查看是否审计成功

MindShow
MindShow

MindShow官网 | AI生成PPT,快速演示你的想法

MindShow 1492
查看详情 MindShow

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表插入数据的事务正常回滚,而审计自治事务不回滚。

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号