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 theOR
REPLACE
clause.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.
compiler_parameters_clause ::=
Name of the library to be recompiled.
Recompiles the library.
During recompilation, the database drops all persistent compiler switch settings, retrieves them again from the session, and stores them after compilation. To avoid this process, specify REUSE
SETTINGS
.
Has the same effect as PLSQL_OPTIMIZE_LEVEL=1
—instructs the PL/SQL compiler to generate and store the code for use by the PL/SQL debugger. Oracle recommends using PLSQL_OPTIMIZE_LEVEL=1
instead of DEBUG
.
Prevents Oracle from dropping and reacquiring compiler switch settings. Preserves the existing settings and uses them for the recompilation of any parameters for which values are not specified elsewhere in this statement.
Has the same behavior for a type as it does for a function. See the ALTER
FUNCTION
"compiler_parameters_clause".
{ 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.
Recompiling a Library: Example 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.