出现原因,是因为在更新的的表和读取的表是同一个表。
CREATE or replace TRIGGER T_userupdateT BEFORE update ON T_user REFERENCING OLD AS old NEW AS N_ROW FOR EACH ROW
DECLARE U_xtfidemp1 varchar(36);
u_xtempcode1 varchar(20);
u_xtempcodeCount int:=0;
U_xtfidempCount int:=0;
u_id1 int:=0;
BEGIN
U_xtfidemp1:=:N_ROW.U_xtfidemp;
u_xtempcode1:=:N_ROW.u_xtempcode;
u_id1:=:N_ROW.u_id;
select count(u_xtempcode) into u_xtempcodeCount from eas.T_user where u_xtempcode is not null and u_xtempcode=u_xtempcode1 and u_id<>u_id1;
select count(U_xtfidemp) into U_xtfidempCount from eas.T_user where U_xtfidemp is not null and U_xtfidemp=U_xtfidemp1 and u_id<>u_id1;
IF u_xtempcodeCount>0 or U_xtfidempCount>0 THEN
RAISE_APPLICATION_ERROR(-20001, 'eas.T_user u_xtempcode,U_xtfidemp,U_GZCode更新数据时有错误,有重复');
END IF;
end;
出现错误时,是因为触发器在T_userupdateT在T_user上,触发器内部有读取了T_user所以有错误。
修改如下
CREATE or replace TRIGGER T_userupdateT BEFORE update ON T_user REFERENCING OLD AS old NEW AS N_ROW FOR EACH ROW
DECLARE U_xtfidemp1 varchar(36);
u_xtempcode1 varchar(20);
u_xtempcodeCount int:=0;
U_xtfidempCount int:=0;
u_id1 int:=0;
PRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
U_xtfidemp1:=:N_ROW.U_xtfidemp;
u_xtempcode1:=:N_ROW.u_xtempcode;
u_id1:=:N_ROW.u_id;
select count(u_xtempcode) into u_xtempcodeCount from eas.T_user where u_xtempcode is not null and u_xtempcode=u_xtempcode1 and u_id<>u_id1;
select count(U_xtfidemp) into U_xtfidempCount from eas.T_user where U_xtfidemp is not null and U_xtfidemp=U_xtfidemp1 and u_id<>u_id1;
IF u_xtempcodeCount>0 or U_xtfidempCount>0 THEN
RAISE_APPLICATION_ERROR(-20001, 'eas.T_user u_xtempcode,U_xtfidemp,U_GZCode更新数据时有错误,有重复');
END IF;
COMMIT;
end;
多了PRAGMA AUTONOMOUS_TRANSACTION;COMMIT;两句
以上这篇Oracle触发器表发生了变化 触发器不能读它的解决方法(必看)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
# oracle
# 触发器
# oracle 存储过程、函数和触发器用法实例详解
# Oracle中触发器示例详解
# 详解oracle中通过触发器记录每个语句影响总行数
# Oracle触发器trigger详解
# Oracle触发器用法实例详解
# oracle 调试触发器的基本步骤
# 是因为
# 给大家
# 希望能
# 两句
# 这篇
# 必看
# 解决方法
# 小编
# 大家多多
# 有错误
# 出现错误
# 发生了
# DECLARE
# ROW
# N_ROW
# u_xtempcodeCount
# int
# varchar
# REFERENCING
# brush
相关文章:
建站主机服务器选购指南:轻量应用与VPS配置解析
网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?
如何在IIS服务器上快速部署高效网站?
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
开封网站制作公司,网络用语开封是什么意思?
如何选择PHP开源工具快速搭建网站?
宝塔建站后网页无法访问如何解决?
青浦网站制作公司有哪些,苹果官网发货地是哪里?
网站制作费用多少钱,一个网站的运营,需要哪些费用?
建站之星代理如何获取技术支持?
如何在橙子建站中快速调整背景颜色?
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
如何快速生成橙子建站落地页链接?
建站之星后台密码如何安全设置与找回?
如何通过免费商城建站系统源码自定义网站主题与功能?
阿里云网站制作公司,阿里云快速搭建网站好用吗?
如何在Golang中使用replace替换模块_指定本地或远程路径
c# Task.ConfigureAwait(true) 在什么场景下是必须的
常州企业网站制作公司,全国继续教育网怎么登录?
如何选择可靠的免备案建站服务器?
如何选购建站域名与空间?自助平台全解析
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
山东网站制作公司有哪些,山东大源集团官网?
再谈Python中的字符串与字符编码(推荐)
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
c++ stringstream用法详解_c++字符串与数字转换利器
行程制作网站有哪些,第三方机票电子行程单怎么开?
网站制作话术技巧,网站推广做的好怎么话术?
如何彻底卸载建站之星软件?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
如何注册花生壳免费域名并搭建个人网站?
如何续费美橙建站之星域名及服务?
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
SQL查询语句优化的实用方法总结
昆明网站制作哪家好,昆明公租房申请网上登录入口?
安徽网站建设与外贸建站服务专业定制方案
如何用IIS7快速搭建并优化网站站点?
香港服务器选型指南:免备案配置与高效建站方案解析
建站之星如何配置系统实现高效建站?
百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
网站制作培训多少钱一个月,网站优化seo培训课程有哪些?
家具网站制作软件,家具厂怎么跑业务?
建站之星下载版如何获取与安装?
如何在香港免费服务器上快速搭建网站?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
香港网站服务器数量如何影响SEO优化效果?
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
h5在线制作网站电脑版下载,h5网页制作软件?
*请认真填写需求信息,我们会在24小时内与您取得联系。