首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | HR | 镜像
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
搜索中心 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>linux数据库>oracle>正文

在Oracle中使用自治事务保存日志表条目

http://www.oklinux.cn  2007-12-05  赛迪网 13291  会员收藏  游客收藏  【 】 
您查看的文章来源于http://www.oklinux.cn

前言:我们知道,数据库的事务是一种单元操作,要么操作全部成功,要么操作全部失败。在Oracle数据库中,一个事务是从执行第一个数据治理语言(DML)语句开始,直到执行一个COMMIT语句,提交保存这个事务,或者执行一个ROLLBACK语句,放弃此次操作结束。

事务的“要么全部完成,要么什么都没完成”的特性会让将错误信息记入数据库表中变得很困难,因为当事务失败重新运行时,用来编写日志条目的INSERT语句还未完成。

针对这种困境,Oracle提供了一种便捷的方法,即自治事务。自治事务从当前事务开始,在其自身的语境中执行。它们能独立地被提交或重新运行,而不影响正在运行的事务。正因为这样,它们成了编写错误日志表格的理想形式。在事务中检测到错误时,您可以在错误日志表格中插入一行并提交它,然后在不丢失这次插入的情况下回滚主事务。

因为自治事务是与主事务相分离的,所以它不能检测到被修改过的行的当前状态。这就似乎在主事务提交之前,它们一直处于单独的会话里,对自治事务来说,它们是不可用的。然而,反过来情况就不同了:主事务能够检测到已经执行过的自治事务的结果。

要创建一个自治事务,您必须在匿名块的最高层或者存储过程、函数、数据包或触发的定义部分中,使用PL/SQL中的PRAGMA AUTONOMOUS_TRANSACTION语句。在这样的模块或过程中执行的SQL Server语句都是自治的。

触发无法包含COMMIT语句,除非有PRAGMA AUTONOMOUS_TRANSACTION标记。但是,只有触发中的语句才能被提交,主事务则不行。

列表1展示了对一个简单但灵活的错误日志表格所作的CREATE TABLE和CREATE SEQUENCE语句。

CREATE TABLE errorlog (
    errorlog_id   NUMBER,
    logged_on     TIMESTAMP   DEFAULT SYSTIMESTAMP,
    logged_by     VARCHAR2(30)      DEFAULT USER,
    num1          NUMBER,
    num2          NUMBER,
    num3          NUMBER,
    text1         VARCHAR2(1000),
    text2         VARCHAR2(1000),
    text3         VARCHAR2(1000)
  );

CREATE SEQUENCE errorlog_seq
    START WITH 1
    INCREMENT BY 1;

列表2是一个独立的存储过程,用于更新错误日志表格。

CREATE OR REPLACE
PROCEDURE log_error (
   n1 IN NUMBER:=NULL, t1 IN VARCHAR:=NULL,
   n2 IN NUMBER:=NULL, t2 IN VARCHAR:=NULL,
   n3 IN NUMBER:=NULL, t3 IN VARCHAR:=NULL
   )
IS

   PRAGMA AUTONOMOUS_TRANSACTION;

BEGIN

   INSERT INTO errorlog
      (errorlog_id,
       num1, num2, num3, text1, text2, text3)
   VALUES
      (errorlog_seq.NEXTVAL, n1, n2, n3, t1, t2, t3);

   COMMIT;

END;

这个过程接受最多三个数字和三个文本变量,然后将它们和时间戳以及调用过程的用户一起储存在表格中。

假如你要测试这个过程,就需要更新(UPDATE)或删除(DELETE)表格中的某些行;这就引发了主事务。然后执行存储过程,将您选择的要记入日志的数据传递给它。最后,重新运行主事务,选择(SELECT)错误日志表格,你的日志条目依旧会在原位置。


上一篇:Oracle9i中如何监视索引并清除监视信息   下一篇:巧用Flashback database功能恢复用户错误

收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·Oracle9i中如何监视索引并清除监视信息
·巧用Flashback database功能恢复用户错误
·解决Oracle非法数据库对象引起的错误
·如何创建访问非"Oracle文件"的外部表格
·Oracle中pfile和spfile之间的联系与区别
·如何使用RMAN和dbv检查数据文件中的坏块
·Oracle数据库中的Instance和数据库的区别
·教你如何在数据字典中修改Oracle的表列名
·了解Oracle11g的新增特性—INTERVAL分区
·实用技巧:取得指定的记录与使用外关联查询
·设置CURSOR_SHARING为SIMILAR后产生的bug
·三个步骤手工扩大Oracle数据库的表空间
·在 Oracle Enterprise Linux 上升级到 Oracle RAC 11g
·巧用sqlldr的WHEN判断加载数据到不同的表
·快速解决 Oracle数据库中 汉字长度的问题
·掌握Oracle数据库密码文件的使用和维护
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·关于Oracle将目标数据库设为归档模式应
·Linux下OCI基础:配置Instant Client连
·Oracle中被锁定的解决办法
·Oracle 11G 无法连接到数据库实例故障
·浅谈创建Oracle数据库连接的两种方法
·如何从Oracle技术支持获得更多
·Oracle数据库中安全知识介绍
·Oracle推出Linux服务并不成功
·Oracle专用服务器的内存结构分布原则
·如何在RAC环境下修改Oracle字符集
·Oracle过程中执行动态SQL或DDL语句
·2008年Oracle错误、备份、升级等最热门
  阅读排行
·详解远程SHELL下安装配置RedHat ES 5的
·Ubuntu上安装Oracle 10G及相关配置
·Oracle高级复制(同步复制)配置步骤详细
·如何修改遗失的MySQL的ROOT用户密码
·Redhat Linux AS4 安装Oracle 10g(包括
·Linux下OCI基础:配置Instant Client连
·解决启动数据库时发生的ORA-12528错误
·在 Oracle Enterprise Linux 上升级到
·Oracle 10g表空间创建的完整步骤
·centos 5.0中成功安装Oracle10g (1020
·如何在RAC环境下修改Oracle字符集
·Oracle数据库导入导出方法的个人总结
·巧用Oracle执行计划机制提高查询性能
·Oracle 10g 在AIX 5.3上安装过程笔记
·Linux真机环境Oracle 10gR2 RAC 安装完
网摘收藏: