oracle编译触发器时老转圈

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle编译触发器时老转圈相关的知识,希望对你有一定的参考价值。

参考技术A TRIGGER **** 编译错误
错误:PLS-00103: 出现符号 "END"在需要下列之一时:
( begin case declare exit
for goto if loop mod null pragma raise return select update
while with <an identifier>
<a double-quoted delimited-identifier> <a bind variable> <<
continue close current delete fetch lock insert open rollback
savepoint set sql execute commit forall merge pipe purge
行:8
文本:end****;

错误原因:
这种时候一般有两种情况,分析如下:
1.掉了结束的符号(如:分号,if的结束end if;最有可能的还是分号),这种属于比较好查的情况,仔细检查即可发现问题。
2.存储过程中可能出现全角的空格,这种错是不可见的,存储过程只接受半角的空格,这种错误属于比较难查的,只能通过断点或者将可能出错的注释点排除查错。实在查不出来,最傻的办法就是重新再手敲输入一遍。
   3.第三种情况一半是很容易忽略的的错误,触发器创建之后必须输入内容,不可为空,否则编译报错。例如:有的人新建了触发器,后来发现触发器不必要,但是又不想删除,于是把内部代码全部注释再去编译,然后就抛出异常的,一个没有内容的触发器是没有存在的必要的,可以删除或者禁用。

为啥在vs中我在头文件中设置了一个文件。在源文件中#include包含。当编译源文件时老说错误

你不能包含txt文件啊,编译器不识别的。必须是头文件或.c/.cpp或其它类似.c/.cpp的文件。但必须是可编译的! 参考技术A 没有txt这种库。。追问

为什么?不是是在头文件中新建一个

参考技术B 库名必须是.h

以上是关于oracle编译触发器时老转圈的主要内容,如果未能解决你的问题,请参考以下文章

oracle12c 中的审计触发器正在编译错误

在 Oracle PL/SQL 中创建触发器时如何解决“编译错误成功”错误?

oracle用imp导入用户数据时,提示表或视图不存在

oracle中 触发器 \'SCOTT.TR_EMP\' 无效且未通过重新验证是啥错误

oracle 触发器

oracle触发器