学院首页 软件应用 编程开发 创意设计 认证培训 软件论坛
ASP ASP.NET PHP JSP SQL MYSQL Java VB

您的位置:学院 >> 编程开发 >> Oracle >> Oracle中使用自治事务保存日志表条目


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


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

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

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

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

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

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

列表A展示了对一个简单但灵活的错误日志表格所作的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;

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

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)错误日志表格,您的日志条目仍会在那儿。

技术文章快速查找

栏目导航
软件应用
·操作系统 ·杀毒防黑 ·应用软件
·聊天软件 ·网络软件  
Web开发
·ASP ·JavaScript ·CGI
·JSP ·VbScript ·Web服务器
·PHP ·XML  
开发语言
·VB ·VC ·ASP.NET
·Java ·C/C++ ·Delphi
数据库开发
·MySQL ·SQL/Access ·PowerBuilder
·Oracle ·DB2  
网站设计
·Flash ·Dreamweaver ·HTML/CSS
·Fireworks ·FrontPage  
平面设计
·Photoshop ·CorelDraw ·AutoCAD
·FreeHand ·Illustrator ·3DsMAX
媒体动画
·Director ·Authorware ·Maya
·视频处理    


相关软件 产品库推荐
·笔记本 ·台式机 ·服务器
·数码相机 ·手机 ·GPS
·DV摄像机 ·MP3 ·MP4
·CPU ·硬盘 ·内存
·主板 ·显卡 ·显示器
·打印机 ·投影机 ·路由器

还没人留言,抢个先,哈哈!
对"Oracle中使用自治事务保存日志表条目"的评论 - 快速回贴
内容:
  [完成后可按Ctrl+Enter发布]

百度中 Oracle中使用自治事务保存日志表条目 相关内容
Google搜索中 Oracle中使用自治事务保存日志表条目 相关内容
雅虎中 Oracle中使用自治事务保存日志表条目 相关内容
Sogou搜索中 Oracle中使用自治事务保存日志表条目 相关内容

相关软件 最新回复帖子:

·Windows Vista 中卸载软件的不同方式
·没有mysql支持时的替代方案
·一个可以发送附件及HTML格式邮件的PHP类
·AutoCAD打造精致三维鸟笼实例详解
·Photoshop自定义水晶字特效样式
·AutoCAD三维基础实例教程
·PS为黑背景长发美女照片抠图换背
·用Photoshop自制个性摩托车贴花小经验
·轻松几步将美女照片处理为手工素描
·巧用Photoshop画笔轻松绘制创意特效


  相关软件 Oracle中使用自治事务保存日志表条目相关文章
有关Oracle数据库10g中的分区功能 详细介绍:Oracle 9i的各技术特征(1)
Oracle数据库备份与恢复的三种方法 在Oracle的网络结构中解决连接问题
简单介绍有关Oracle数据库备份技巧 ASP.NET 2.0实现依赖Oracle的缓存策略
基于Oracle ADF的应用程序开发过程 有关 Oracle 的架构的基础知识简介
ORACLE学习笔记之调节性能优化篇 教你如何来恢复一个丢失的数据文件
Oracle数据库基本知识及问题解决 如何应对ORACLE数据库的部分面试题目
Oracle数据库的安全策略分析(一) Oracle的TNS-12502错误原因及解决
Oracle 9i 数据库WITH查询语法小议 有关Oracle Index 的三个问题(二)
ORACLE与SQL SERVER语言比较(一) 有关Oracle Index 的三个问题(一)
Oracle 10g的安装步骤和注意事项 Oracle 的数据库的数据备份与恢复