Oracle 触发器调试及遇到相关问题解决

Oracle 触发器调试及遇到相关问题解决,第1张

今天在项目中遇到一个比较棘手的问题,需要用到触发器。在编写触发器和调试过程中遇到下列问题,在此记录一下:

    由于之前写的触发器都能正常运行,就没有涉及到触发器的调试,今天发现触发器没起作用,需要调试,竟不知道在哪儿调试。在网上借鉴一些别人的经验(https://blog.csdn.net/jiutianhe/article/details/17240695),记录一下。在PL/SQL中,触发器的调试方法如下:

1,选中要调试的触发器,右击,然后勾选 Add debug information,只有勾选这个按钮后,调试才能进入到断点。

2,选中触发器,点击 Edit,到Edit 界面,在要调试的行号前面单击,或者右键,添加断点。

3,在菜单的新建中选择“测试窗口”,打开一个如下块,在begin和end中间添加能触发触发器的语句

4,按F9或者点击调试菜单中的开始菜单,进入运行调试状态(后面的红框是单步进入)

5,点击运行图标跳到触发器中断点位置

6,鼠标放到变量上可以显示变量值。

7,如果有异常,就d出相关异常信息。

    调试的时候发现new对象的日期格式为中文,而后面又需要yyyy-mm-dd 的格式来作为查询条件。所以就在赋值的时候转换一下。

在select into 给变量赋值的时候,select 查询出来的集合为空,导致报错ORA-01403,解决方案就是将这一段用begin end 包裹起来,抛出改异常的时候给变量一个默认值。如下图:

一般在sqlplus或者其他第三方oracle工具中,按照语法及需求写好代码,直接执行创建过程即可。

一般语法如下:

CREATE [OR REPLACE] TRIGGER trigger_name

{BEFORE | AFTER }

{INSERT | DELETE | UPDATE [OF column [, column …]]}

[OR {INSERT | DELETE | UPDATE [OF column [, column …]]}...]

ON [schema.]table_name | [schema.]view_name 

[REFERENCING {OLD [AS] old | NEW [AS] new| PARENT as parent}]

[FOR EACH ROW ]

[WHEN condition]

PL/SQL_BLOCK | CALL procedure_name

创建两个表:

create table a

(stdid int,

stdname varchar2(10))

create table b

(stdid int,

stdname varchar2(10))

创建触发器:

CREATE OR REPLACE TRIGGER tr_insert

after insert

ON a

FOR EACH ROW

BEGIN

INSERT INTO b(stdid,stdname)

VALUES(:new.stdid,:new.stdname)

END

验证,在a表中插入数据:

insert into a values (1,'a')

commit

验证b表结果:

如果业务需要在插入前作判断

就是说  当且仅当 表A插入的 stdid在表C中存在  也就是说

表A新插入的的 stdid in   select stdid from C 时 才执行下面插入表B的动作

创建个c表

create table c

(stdid int)

插入一条数据:

insert into c values (1)

commit

触发器修改为:

CREATE OR REPLACE TRIGGER tr_insert

after insert

ON a

FOR EACH ROW

declare  v_count int

BEGIN

select count(*) into v_count from c where stdid =:new.stdid

if v_count=0

then

INSERT INTO b(stdid,stdname)

VALUES(:new.stdid,:new.stdname)

end if

END

然后分别往a表中插入id=1和id=2的数据,剩下的自己验证吧, 不给你截图了


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/bake/11728016.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-18
下一篇2023-05-18

发表评论

登录后才能评论

评论列表(0条)

    保存