搜索
首页数据库mysql教程用DBMS_DDL包重新编译PL/SQL对象

ALTER_COMPILE过程 这个过程等价于如下语句 ALTER PROCEDURE|FUNCTION|PACKAGE [ .] COMPILE [BODY] 语法 DBMS_DDL.ALTER_COMPILE ( type VARCHAR2, schema VARCHAR2, name VARCHAR2); 参数: 现在,如果想重 编译 一个程序,Oracle首先会重 编译 被标识invali

ALTER_COMPILE过程

这个过程等价于如下语句

ALTER PROCEDURE|FUNCTION|PACKAGE [.] COMPILE [BODY]

语法

DBMS_DDL.ALTER_COMPILE (

type

VARCHAR2,

schema VARCHAR2,

name

VARCHAR2);

参数:

用DBMS_DDL包重新编译PL/SQL对象


现在,如果想重编译一个程序,Oracle首先会重编译被标识invalid的程序所依赖的所有对象.

例1:

编译MYUSER方案的ACCESS_RIGHTS过程:

DBMS_DDL.ALTER_COMPILE('PROCEDURE','MYUSER','ACCESS_RIGHTS');

例2:

差不多每个实例中,PL/SQL对象名称以大写方式存储,如果创建时指定一个双引号的对象名称,那么当编译时应指定同样的方式.

如果指定不正确,则会报以下的错误

SQL> dbms_ddl.alter_compile('PROCEDURE','MYUSER','access_rights');

BEGIN dbms_ddl.alter_compile('PROCEDURE','MYUSER','access_rights'); END;

*

ERROR at line 1:

ORA-20000: Unable to compile PROCEDURE "MYUSER"."access_rights",

insufficient privileges or does not exist

ORA-06512: at "SYS.DBMS_DDL", line 68

ORA-06512: at line 1

因此如果你创建如下的对象:

CREATE or REPLACE PROCEDURE "My_Object" IS

BEGIN

...

得使用:

DBMS_DDL.ALTER_COMPILE('PROCEDURE','MYUSER','My_Object');

也可以使用ALTER PROCEDURE COMPILE命令来编译对象,用DBMS_DDL包最大的优势在于可以在以后的程序或PL/SQL中编译,这将拥有完全的灵活性以创建强有力的使用价值(请参照如下例子)

例3:

这个例子将获得所有无效的对象并且重新编译

set termout on

set serverout on

DECLARE

cursor cur_invalid_objects is

select object_name, object_type from user_objects where status='INVALID';

rec_columns cur_invalid_objects%ROWTYPE;

err_status NUMERIC;

BEGIN

dbms_output.enable(10000);

open cur_invalid_objects;

loop

fetch cur_invalid_objects into rec_columns;

EXIT WHEN cur_invalid_objects%NOTFOUND;

dbms_output.put_line

('Recompiling ' || rec_columns.object_type || '

' || rec_columns.object_name);

dbms_ddl.alter_compile(rec_columns.object_type,NULL,rec_columns.object_name);

end loop;

close cur_invalid_objects;

EXCEPTION

When others then

begin

err_status := SQLCODE;

dbms_output.put_line(' Recompilation failed : ' || SQLERRM(err_status));

if ( cur_invalid_objects%ISOPEN) then

CLOSE cur_invalid_objects;

end if;

exception when others then

null;

end;

end;

/

总结:

ALTER_COMPILE可以代替手工而自动编译对象,查找那些无效的对象从而一个一个地编译.
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
C++编译报错:未声明的标识符,如何解决?C++编译报错:未声明的标识符,如何解决?Aug 22, 2023 pm 03:34 PM

在使用C++进行编程时,经常会遇到未声明的标识符这个问题。这种情况通常发生在使用了未定义的变量、函数或类时,导致编译器无法识别这些标识符,进而产生编译错误。本文将介绍导致未声明的标识符问题的常见原因以及如何解决这个问题。常见原因未声明的标识符问题通常由以下几种原因导致:变量、函数或类未被正确声明:在使用变量、函数或类之前,应该先声明它们。如果变量未被声明或函

Java 中的编译和反编译技术Java 中的编译和反编译技术Jun 09, 2023 am 09:43 AM

Java是一种非常流行的编程语言,广泛应用于开发各种类型的软件。在Java开发中,编译和反编译技术是非常重要的环节。编译技术用于将Java代码转换成可执行文件,而反编译技术则允许人们将可执行文件重新转换回Java代码。本文将介绍Java中的编译和反编译技术。一、编译技术编译是将高级语言(如Java)代码转换为机器语言的过程。在Java

为什么我的Go程序需要更长的时间来编译?为什么我的Go程序需要更长的时间来编译?Jun 09, 2023 pm 06:00 PM

近年来,Go语言已经成为了越来越多开发者的选择。但是,相比其他编程语言而言,Go语言的编译速度却不够快。很多开发者在编译Go程序时都会遇到这样的问题:为什么我的Go程序需要更长时间来编译?本文将会从几个方面探讨这个问题。Go语言的编译器架构Go语言的编译器架构采用的是三阶段设计,分别是前端、中间层和后端。前端负责将源代码翻译成Go语言的中间代码,中间层则将中

linux为什么要编译源码linux为什么要编译源码Mar 17, 2023 am 10:21 AM

原因:1、Linux发型版本众多,但是每个版本采用的软件或者内核版本都不一样,而二进制包所依赖的环境不一定能够正常运行,所以大部分软件直接提供源码进行编译安装。2、方便定制,满足不同的需求。3、方便运维、开发人员维护;源码是可以打包二进制的,但是对于这个软件的打包都会有一份代价不小的额外工作,包括维护,所以如果是源码的话,软件产商会直接维护。

C++编译错误:函数参数列表太长,应该怎么解决?C++编译错误:函数参数列表太长,应该怎么解决?Aug 21, 2023 pm 11:19 PM

C++编译错误:函数参数列表太长,应该怎么解决?在使用C++编写程序时,有时候会遇到这样的编译错误:函数参数列表太长。对于C++初学者来说,这可能是一个很头疼的问题。接下来,我们将介绍这个问题的原因和解决方法。首先,让我们来看一下C++函数参数的基本规定。在C++中,函数参数必须在函数名和左括号之间声明。当你传递函数参数时,告诉函数要做什么。这些参数可以是任

go语言能不能编译go语言能不能编译Dec 09, 2022 pm 06:20 PM

go语言能编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言。对Go语言程序进行编译的命令有两种:1、“go build”命令,可以将Go语言程序代码编译成二进制的可执行文件,但该二进制文件需要手动运行;2、“go run”命令,会在编译后直接运行Go语言程序,编译过程中会产生一个临时文件,但不会生成可执行文件。

go语言程序如何编译go语言程序如何编译Jun 04, 2021 pm 02:31 PM

编译go语言程序的方法:1、在命令行工具中执行“go build fileName”命令,会将程序代码编译成二进制的可执行文件;2、在命令行工具中执行“go run fileName”命令,它会在编译后直接运行Go语言程序。

C++编译错误:参数数量错误,该怎么修改?C++编译错误:参数数量错误,该怎么修改?Aug 22, 2023 am 09:31 AM

C++编译错误:参数数量错误,该怎么修改?在编写C++程序时,我们经常会遇到各种编译错误。其中一个常见的错误就是参数数量错误。当我们编写函数时,如果函数的参数数量和类型与调用该函数时提供的参数不匹配,就会导致编译错误。在C++中,编译器会在编译时检查函数参数的数量和类型,因此,我们需要确保函数参数的匹配性以避免编译错误。那么,当我们遇到C++编译错误:参数数

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前By尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器