首页 数据库 mysql教程 Oracle中变异表处理办法

Oracle中变异表处理办法

Jun 07, 2016 pm 05:25 PM
o 数据库

在Oracle数据库中,变异表是当前被DML语句修改的表。而对于数据库上的triggrt(触发器)来说,变异表就是trigger在其上定义的表。需

Oracle变异表

在Oracle数据库中,变异表是当前被DML语句修改的表。

而对于数据库上的triggrt(触发器)来说,变异表就是trigger在其上定义的表。

需要明确的是trigger中SQL语句不能进行如下操作:   

1)读或者修改触发语句的任何变异表,包括触发表本身。   

2)读或者修改触发表的约束表中的主关键字,唯一关键字和外部关键字。   

而除此之外的其他列都可以修改。   

如何突破变异表?   

方法一是用两个触发器,一个行级的,一个语句级的(速度快,推荐!)   

方法二是用dbms_job.run包(但运行的时间过长,2秒左右)   

方法三是可以使用AutoCommit方法解决(但破坏了事务的一致性,多数情况下是错误的)。

下面是包 + 行级触发器 + 语句级触发器的实例:

在使用Oracle行级触发器时,如果需要对本表进行DML操作(包括select),,一般都会报错:

ORA-04091: 表 /**TABLENAME**/ 发生了变化,触发器/函数不能读···

一般可以使用“ 包 + 行级触发器 + 语句级触发器 ”组合使用来解决。

 

// 创建包

CREATE OR REPLACE PACKAGE BRPMS.FXYDATA AS
  TYPE T_COL1 IS TABLE OF BRPMS.TB_RISK_FXY.GUID%TYPE INDEX BY BINARY_INTEGER;
  V_GUID T_COL1;
  V_ROW  BINARY_INTEGER := 0;
END;

// 创建行级触发器

CREATE OR REPLACE TRIGGER BRPMS.T_IFFXYMODIFIED
  BEFORE UPDATE OF FXFXJDON BRPMS.TB_RISK_FXY
  FOR EACH ROW
BEGIN
  IF :NEW.JHLX = '1' THEN
    IF :NEW.FXFXJD = '已发布' THEN
      BRPMS.FXYDATA.V_ROW  := BRPMS.FXYDATA.V_ROW + 1;
      BRPMS.FXYDATA.V_GUID(BRPMS.FXYDATA.V_ROW) := :NEW.GUID;
    END IF;
  END IF;
END;


// 创建语句级触发器

CREATE OR REPLACE TRIGGER BRPMS.T_COPY_Y2R
  AFTER UPDATE OF FXFXJD ON BRPMS.TB_RISK_FXY
DECLARE
  S_YJHID BRPMS.TB_RISK_FXY.GUID%TYPE;
  S_RJHID BRPMS.TB_RISK_FXY.GUID%TYPE;
BEGIN
  FOR V_LOOP IN 1 .. BRPMS.FXYDATA.V_ROW LOOP
    S_YJHID := BRPMS.FXYDATA.V_GUID(V_LOOP);
    SELECT (SELECT F.GUID FROM BRPMS.TB_RISK_FXY F WHERE F.TDJH_ID = R.GUID)
      INTO S_RJHID
      FROM (SELECT * FROM BRPMS.TB_RISK_TDJH WHERE JHLX = 1) Y,
          (SELECT * FROM BRPMS.TB_RISK_TDJH WHERE JHLX = 2) R
    WHERE Y.YXTJHBH = R.YJHZJ
      AND EXISTS
    (SELECT FXY.GUID
              FROM BRPMS.TB_RISK_FXY FXY
            WHERE FXY.TDJH_ID = R.GUID)
      AND Y.GUID =
          (SELECT F.TDJH_ID FROM BRPMS.TB_RISK_FXY F WHERE F.GUID = S_YJHID)
      AND ROWNUM = 1;
    IF S_RJHID IS NOT NULL THEN
      BRPMS.P_COPY_Y2R_MANUAL(S_YJHID, S_RJHID);
    END IF;
  END LOOP;
END;

linux

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 Jul 18, 2024 am 05:48 AM

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

在PHP中使用MySQLi建立数据库连接的详尽教程 在PHP中使用MySQLi建立数据库连接的详尽教程 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

如何在PHP中处理数据库连接错误 如何在PHP中处理数据库连接错误 Jun 05, 2024 pm 02:16 PM

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

如何在 Golang 中使用数据库回调函数? 如何在 Golang 中使用数据库回调函数? Jun 03, 2024 pm 02:20 PM

在Golang中使用数据库回调函数可以实现:在指定数据库操作完成后执行自定义代码。通过单独的函数添加自定义行为,无需编写额外代码。回调函数可用于插入、更新、删除和查询操作。必须使用sql.Exec、sql.QueryRow或sql.Query函数才能使用回调函数。

btc交易app怎么安装注册? btc交易app怎么安装注册? Feb 21, 2025 pm 07:09 PM

本篇文章将详细介绍如何安装和注册比特币交易应用。比特币交易应用允许用户管理和交易比特币等加密货币。文章逐步指导用户完成安装和注册过程,包括下载应用程序、创建账户、进行身份验证和首次存款。文章的目标是为初学者提供清晰易懂的指南,帮助他们轻松进入比特币交易的世界。

如何在 Golang 中将 JSON 数据保存到数据库中? 如何在 Golang 中将 JSON 数据保存到数据库中? Jun 06, 2024 am 11:24 AM

可以通过使用gjson库或json.Unmarshal函数将JSON数据保存到MySQL数据库中。gjson库提供了方便的方法来解析JSON字段,而json.Unmarshal函数需要一个目标类型指针来解组JSON数据。这两种方法都需要准备SQL语句和执行插入操作来将数据持久化到数据库中。

Go WebSocket 如何与数据库集成? Go WebSocket 如何与数据库集成? Jun 05, 2024 pm 03:18 PM

如何将GoWebSocket与数据库集成:设置数据库连接:使用database/sql包连接到数据库。将WebSocket消息存储到数据库:使用INSERT语句将消息插入数据库。从数据库检索WebSocket消息:使用SELECT语句检索数据库中的消息。

PHP 数据库连接陷阱:避免常见的错误和误区 PHP 数据库连接陷阱:避免常见的错误和误区 Jun 05, 2024 pm 10:21 PM

要避免PHP数据库连接错误,请遵循最佳实践:检查连接错误,变量名称与凭据匹配。使用安全存储或环境变量,避免硬编码凭据。使用完后关闭连接,防止SQL注入,使用准备好的语句或绑定参数。

See all articles