Oralce 触发器

摘要:
操作立即生效,原数据不放到rollbacksegment中,不能回滚.操作不触发triggerDML数据操纵语言命令使用户能够查询数据库以及操作已有数据库中的数据。

今天做了一个需要用到触发器实现的功能中间去到了各种问题,还好最后都解决了;

整个过程中真是遇到了不少错误:

ORA-04091: 表 KPGO.T_ISSUER 发生了变化, 触发器/函数不能读它

ORA-04092: COMMIT 不能在触发器中

ORA-04098:触发器“xx.xxx”无效且未通过重新定义

首先说第一个错是因为这样的代码:

Oralce 触发器第1张

原因是

触发器和存储过程中中用:再次去查目标表(就是你触发器服务的那张表),这一动作被oracle认为是不合法的。

目标表的记录行如果做了更新,无需再通过ID去查询目标记录行。这一动作被oracle认为是不合法的。

那咋整!!!咱也不知道,咱也不知道问谁,拉倒吧自己百度

嗯!!!就在那么一瞬间我看到了一个似乎可以拯救我得答案,它得变量赋值方式我很喜欢,必须咱也得弄(neng四声)一下

Oralce 触发器第2张

嗯整挺好 不在报那个错了

但是啊 人啊不能太嚣张 紧接着给我整了个第二个错 ORA-04092: COMMIT 不能在触发器中

当时脑瓜带 嗡一下子 我努力让自己清醒 磕了一袋瓜子喝了杯茶水 我又意识到

触发器里面是不能执行ddl语句和commit操作的 原因就在调用得那个函数里面

既然问题找到了 干他

Oralce 触发器第3张

DDL语句用语定义和管理数据库中的对象,如Create,Alter,Drop,truncate等;

DDL操作是隐性提交的!操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger

DML(Data Manipulation Language)数据操纵语言命令使用户能够查询数据库以及操作已有数据库中的数据。
如insert,delete,update,select等都是DML.

虽然在触发器里没有写ddl语句但是tm这个函数里有,wc我这小脾气就上来了,又是一顿小百度

Oralce 触发器第4张

为触发器添加自治事务,完美解决

至于ORA-04098:触发器“xx.xxx”无效且未通过重新定义这个错,一般就是没仔细有写错得地方,好好看看

还有就是如果你的数据库链接工具是navicat 那你得看看你的触发器是不是完整的,有的时候他可能只给你编译了一半

到这里就OK了,工作以来第一次写触发器,记录一下方便学习

重点:

1.oracle触发器中定义变量得赋值方式要注意下,选择适合自己需求的

2.触发器中每一句语句都要有分号,别懒

3.触发器不能执行ddl语句和commit操作,如果想用加自治事务(但是我好像见过专门的ddl触发器但是真的得是表什么得。。想了解得自己查吧)

免责声明:文章转载自《Oralce 触发器》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇【转】六、android图片特效处理之图片叠加VS2015远程调试下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

zabbix Server 4.0 触发器(Trigger)篇

zabbix Server 4.0 触发器(Trigger)篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任。 一.触发器(Trigger)概述 1>.上一篇博客我们介绍了“内置item使用案例”,item(监控项)仅负责收集数据,而通常收集数据的目的还包括在某指标对应的数据超出合理范围时给先关人员发送告警信息,“触发器”正是用于为...

sql server触发器 :当一个表发生插入或更新时,将数据同步到另一张表中

  ALTER  triggerMonitor_Dic_date_Up  on [dbo].[DIC_DATA]--触发器对象表   for update ,insert--插入或更新时触发.   as --  begin   if EXISTS(select 1 from DIC_DATAupdate  A ,inserted B where A....

SqlServer基础之(触发器)

SqlServer基础之(触发器)  阅读目录 一:触发器的优点 二:触发器的作用 三:触发器的分类 四:触发器的工作原理 五:创建触发器 六:管理触发器  概念:   触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是...

Mysql----浅入浅出之视图、存储过程、触发器

一、视图 VIEW 视图是虚拟的表,本身不存储不论什么数据。仅仅有执行时,才包括动态检索出来的数据。 eg:SELECT sid, name, sex, s_num FROM  student, school WHERE sid = 2 AND student.sid = scholl.sid ; 这个简单的查询涉及到两个表。 所以不论什么须要这个数据的...

MySQL触发器Trigger实例篇

定义: 何为MySQL触发器? 在MySQL Server里面也就是对某一个表的一定的操作,触发某种条件(Insert,Update,Delete 等),从而自动执行的一段程序。从这种意义上讲触发器是一个特殊的存储过程。下面通过MySQL触发器实例,来了解一下触发器的工作过程吧! 一、创建MySQL实例数据表: 在mysql的默认的测试test数据库下,...

zabbix触发器表达式

zabbix触发器表达式 触发器使用逻辑表达式来评估通过item获取的数据是处于哪种状态, 触发器中的表达式使用很灵活,我们可以创建一个复杂的逻辑测试监控,触发器表达式形式如下: {<server>:<key>.<function>(<parameter>)}<operator><const...