15.2 ALTER LIBRARY Statement
The ALTER
LIBRARY
statement explicitly recompiles a library.
Explicit recompilation eliminates the need for implicit runtime recompilation and prevents associated runtime compilation errors and performance overhead.
Note:
This statement does not change the declaration or definition of an existing library. To redeclare or redefine a library, use the "CREATE LIBRARY Statement" with the OR
REPLACE
clause.
Topics
Prerequisites
If the library is in the SYS
schema, you must be connected as SYSDBA
. Otherwise, the library must be in your schema or you must have the ALTER
ANY
LIBRARY
system privilege.
Syntax
alter_library ::=
library_compile_clause ::=
Semantics
alter_library
library_name
Name of the library to be recompiled.
{ EDITIONABLE | NONEDITIONABLE }
Specifies whether the library becomes an editioned or noneditioned object if editioning is later enabled for the schema object type LIBRARY
in schema
. Default: EDITIONABLE
. For information about altering editioned and noneditioned objects, see Oracle Database Development Guide.
library_compile_clause
Recompiles the library.
See compile_clause and compiler_parameters_clause semantics.Example
Example 15-2 Recompiling a Library
To explicitly recompile the library my_ext_lib
owned by the sample user hr
, issue this statement:
ALTER LIBRARY hr.my_ext_lib COMPILE;
If the database encounters no compilation errors while recompiling my_ext_lib
, then my_ext_lib
becomes valid. The database can subsequently run it without recompiling it at run time. If recompiling my_ext_lib
results in compilation errors, then the database returns an error, and my_ext_lib
remains invalid.
The database also invalidates all objects that depend upon my_ext_lib
. If you subsequently reference one of these objects without explicitly recompiling it first, then the database recompiles it implicitly at run time.
Related Topics