Thursday, September 15, 2011

Oracle 10g features

CHARACTERSTICS

Ø  Highly structured, readable and accessible language.
Ø  Standard and Protable language.
Ø  Embedded language.
Ø  Improved execution authority.

10g FEATURES

Ø  Optimized compiler.
To change the optimizer settings for the entire database, set the database parameter
PLSQL_OPTIMIZE_LEVEL. Valid settings are as follows
0          -           No optimization
1          -           Moderate optimization
2          -           Aggressive optimization

These settings are also modifiable for the current session.
SQL> alter session set plsql_optimze_level=2;

Oracle retains optimizer settings on a module-by-module basis. When you recompile a particular module with nondefault settings, the settings will stick allowing you to recompile later on using REUSE SETTINGS.
SQL> Alter procedure proc compile plsql_optimize_level=1;
SQL> Alter procedure proc compile reuse settings;

Ø  Compile-time warnings.
Starting with oracle database 10g release 1 you can enable additional compile-time warnings to help make your programs more robust. The compiler can detect potential runtime problems with your code, such as identifying lines of code that will never be run. This process, also known as lint checking.

To enable these warnings fo the entire database, set the database parameter PLSQL_WARNINGS.
These settings are also modifiable for the current session.
SQL> alter session set plsql_warnings = ‘enable:all’;
The above can be achieved using the built-in package DBMS_WARNING.

Ø  Conditional compilation.
Conditional compilation allows the compiler to allow to compile selected parts of a program based on conditions you provide with the $IF directive.

Ø  Support for non-sequential collections in FORALL.
Ø  Improved datatype support.

Ø  Backtrace an exception to its line number.
When handling an error, how can you find the line number on which the error was originally raised?

In earlier release, the only way to do this was allow you exception to go unhandled and then view the full error trace stack.

Now you can call DBMS_UTILITY.FORMAT_ERROR_BACKTRACE function to obtain that stack and manipulate it programmatically within your program.

Ø  Set operators for nested tables.

Ø  Support for regular expressions.
Oracle database 10g supports the use of regular expressions inside PL/SQL code via four new built-in functions.
ü  REGEXP_LIKE
ü  REGEXP_INSTR
ü  REGEXP_SUBSTR
ü  REGEXP_REPLACE

Ø  Programmer-defined quoting mechanism.
Starting with oracle database 10g release 1, you can define your own quoting mechanism for string literals in both SQL and PL/SQL.
Use the characters q’(q followed by a single quote) to note the programmer-defined deliemeter for you string literal.
Ex:
            DECLARE
     v varchar(10) := 'computer';
BEGIN
     dbms_output.put_line(q'*v = *' || v);
     dbms_output.put_line(q'$v = $' || v);
END;

Output:
            v = computer
v = computer

Ø  Many new built-in packages.
DBMS_SCHEDULER
Represents a major update to DBMS_JOB. DBMS_SCHEDULER provides much improved functionality for scheduling and executing jobs defined via stored procedures.

DBMS_CRYPTO
Offers the ability to encrypt and decrypt common oracle datatype, including RAWs, BLOBs, and CLOBs. It also provides globalization support for encrypting data across different charactersets.

DBMS_MONITOR
Provides an API to control additional tracing and statistics gathering of sessions.

DBMS_WARNING
Provides an API into the PL/SQL compiler warnings module, allowing you to read and change settings that control which warnings are suppressed, displayed, or treated as errors.

No comments:

Post a Comment

Oracle Escape Characters

Oracle allows the assignment of special escape characters to tell Oracle that the character is interpreted literally.  Certain characters ...