重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

oracle如何编译无效 oracle编译无效对象

Oracle 定义存储过程 不能执行,处于无效状态。

无效状态有两种可能:

成都创新互联公司是一家专业提供柞水企业网站建设,专注与成都网站制作、做网站、外贸营销网站建设H5开发、小程序制作等业务。10年已为柞水众多企业、政府机构等服务。创新互联专业网站制作公司优惠进行中。

1、一种是你的存储过程编辑没有成功,创建了,但里面有语法错误。

2、还有一种是存储过程使用的表有结构上的改变,需要重新编译一下。

解决方法如下:

重新编译一下,如果不成功,就是有语法问题,你需要修改存储过程。

延展阅读:

修改存储过程的操作:在你的存储过程,鼠标右键,点修改,再保存就行了。

如何在Oracle中重编译所有无效的存储过程

:在SQL_PLUS中:spool ExecCompProc.sql select 'alter procedure ' ||object_name||' compile;' From all_objects where status = 'INVALID' and object_type = 'PROCEDURE'; spool off @ExecCompProc.Sql;整理成一个存储过程:Create Or Replace Procedure Zl_Compile_Invalid_Procedure AsStrsql Varchar2(200);BeginFor x In (Select Object_Name From All_Objects Where Status = 'INVALID' And Object_Type = 'PROCEDURE') LoopStrsql := 'Alter Procedure ' || x.Object_Name || ' Compile';Begin Execute Immediate Strsql; Exception--When Others Then Null; When OTHERS Then dbms_output.put_line(Sqlerrm); End;End Loop;End;最后执行:exec Zl_Compile_Invalid_Procedure;如果要看到无法重编译的过程的出错信息,需要执行前设置set serverout on。

如何重编译ORACLE数据库的无效对象

如果无效对象的数量很少,那么你可以逐个编译这些对象.

ALTER PACKAGE my_package COMPILE;

ALTER PACKAGE my_package COMPILE BODY;

ALTER PROCEDURE my_procedure COMPILE;

ALTER FUNCTION my_function COMPILE;

ALTER TRIGGER my_trigger COMPILE;

ALTER VIEW my_view COMPILE;

oracle 过程 重新编译也无效

编译完成,不代表里面语句没问题,这种情况是存储过程里存在某种错误

在 SQL *Plus 或者 PL/SQL Developer 的 Command Windows 中,执行

show errors procedure USP_EXCEPTION;

查看一下错误是什么.

我的修改如下:

CREATE OR REPLACE PROCEDURE USP_EXCEPTION(EMPNO INTEGER, --批次ID

P_FM NUMBER, --分母

P_FZ NUMBER, --分子

P_RESULT OUT NUMBER --结果

) IS

V_RAISE EXCEPTION; --异常处理

type type_table_pcmx is varray(4) of varchar2(20);

TABLE_PCMX type_table_pcmx;

BEGIN

IF P_FZ = 0 THEN

RAISE V_RAISE;

END IF;

P_RESULT := P_FM / P_FZ;

SELECT ENAME, EMPNO, JOB, DEPTNO

INTO TABLE_PCMX(1),TABLE_PCMX(2),TABLE_PCMX(3),TABLE_PCMX(4)

FROM EMP

WHERE EMPNO = EMPNO;

EXCEPTION

WHEN V_RAISE THEN

RAISE_APPLICATION_ERROR(-20010, 'ERROR:分子为零!');

WHEN NO_DATA_FOUND THEN

RAISE_APPLICATION_ERROR(-20011, 'ERROR:批次明细不存在!');

WHEN OTHERS THEN

RAISE_APPLICATION_ERROR(-20012, 'ERROR:数据错误!');

END;


本文标题:oracle如何编译无效 oracle编译无效对象
分享地址:http://cqcxhl.cn/article/hiejjd.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP