Oracle中变异表处理办法
在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;

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

蘋果公司最新發布的iOS18、iPadOS18以及macOSSequoia系統為Photos應用程式增添了一項重要功能,旨在幫助用戶輕鬆恢復因各種原因遺失或損壞的照片和影片。這項新功能在Photos應用的"工具"部分引入了一個名為"已恢復"的相冊,當用戶設備中存在未納入其照片庫的圖片或影片時,該相冊將自動顯示。 "已恢復"相簿的出現為因資料庫損壞、相機應用未正確保存至照片庫或第三方應用管理照片庫時照片和視頻丟失提供了解決方案。使用者只需簡單幾步

MySQL是一個開源的關係型數據庫管理系統。 1)創建數據庫和表:使用CREATEDATABASE和CREATETABLE命令。 2)基本操作:INSERT、UPDATE、DELETE和SELECT。 3)高級操作:JOIN、子查詢和事務處理。 4)調試技巧:檢查語法、數據類型和權限。 5)優化建議:使用索引、避免SELECT*和使用事務。

本文推薦全球十大數字貨幣交易APP,涵蓋幣安(Binance)、OKX、火幣(Huobi Global)、Coinbase、Kraken、Gate.io、KuCoin、Bitfinex、Gemini和Bitstamp。這些平台在交易對數量、交易速度、安全性、合規性、用戶體驗等方面各有特色,例如幣安以其高交易速度和廣泛服務聞名,而Coinbase則更適合新手用戶。選擇適合自己的平台需要綜合考慮自身需求和風險承受能力。 了解全球主流數字貨幣交易平台,助您安全高效進行數字資產交易。

本篇文章將詳細介紹如何安裝和註冊比特幣交易應用。比特幣交易應用允許用戶管理和交易比特幣等加密貨幣。文章逐步指導用戶完成安裝和註冊過程,包括下載應用程序、創建賬戶、進行身份驗證和首次存款。文章的目標是為初學者提供清晰易懂的指南,幫助他們輕鬆進入比特幣交易的世界。

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

歐易,又稱OKX,是一個全球領先的加密貨幣交易平台。文章提供了歐易官方安裝包的下載入口,方便用戶在不同設備上安裝歐易客戶端。該安裝包支持 Windows、Mac、Android 和 iOS 系統,用戶可根據自己的設備類型選擇相應版本下載。安裝完成後,用戶即可註冊或登錄歐易賬戶,開始交易加密貨幣和享受平台提供的其他服務。

MySQL適合Web應用和內容管理系統,因其開源、高性能和易用性而受歡迎。 1)與PostgreSQL相比,MySQL在簡單查詢和高並發讀操作上表現更好。 2)相較Oracle,MySQL因開源和低成本更受中小企業青睞。 3)對比MicrosoftSQLServer,MySQL更適合跨平台應用。 4)與MongoDB不同,MySQL更適用於結構化數據和事務處理。
