全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Oracle触发器表发生了变化 触发器不能读它的解决方法(必看)

出现原因,是因为在更新的的表和读取的表是同一个表。

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小时内与您取得联系。