The DBMS_HPROF package provides an interface for profiling the execution of PL/SQL applications. It provides services for collecting the hierarchical profiler data, analyzing the raw profiler output and profiling information generation.
This chapter contains the following topic:
See Also:
Oracle Database Development Guide for more information about the "PL/SQL Hierarchical Profiler"
This table lists and briefly describes the DBMS_HPROF package subprograms.
Table 79-1 DBMS_HPROF Package Subprograms
| Subprogram | Description | 
|---|---|
| Analyzes the raw profiler output and produces hierarchical profiler information in database tables | |
| Starts hierarchical profiler data collection in the user's session | |
| Stops profiler data collection in the user's session.s | 
This function analyzes the raw profiler output and produces hierarchical profiler information in database tables.
Syntax
DBMS_HPROF.ANALYZE ( location VARCHAR2, filename VARCHAR2, summary_mode BOOLEAN DEFAULT FALSE, trace VARCHAR2 DEFAULT NULL, skip PLS_INTEGER DEFAULT 0, collect PLS_INTEGER DEFAULT NULL, run_comment VARCHAR2 DEFAULT NULL) RETURN NUMBER;
Parameters
Table 79-2 ANALYZE Function Parameters
| Parameter | Description | 
|---|---|
| 
 | Name of a directory object. The raw profiler data file is read from the file system directory mapped to this directory object. Output files are also written to this directory. | 
| 
 | Name of the raw profiler data file to be analyzed. The file must exist in the directory specified by the  | 
| 
 | By default (that is, when  | 
| 
 | Analyze only the subtrees rooted at the specified trace entry. By default (when trace is  The trace entry must be specified in a special quoted qualified format (including the schema name, module name & function name) as in for example, '" | 
| 
 | Used only when  | 
| 
 | Used only when  Analyze  | 
| 
 | User-provided comment for this run | 
Return Values
A unique run identifier for this run of the analyzer. This can then be used to look up the results corresponding to this run from the hierarchical profiler tables.
Usage Notes
Use the dbmshptab.sql script located in the rdbms/admin directory to create the hierarchical profiler database tables and other data structures required for persistently storing the results of analyzing the raw profiler data.
Running dbmshptab.sql drops the any previously created hierarchical profiler tables.
Examples
The following snippet installs the hierarchical profiler tables in HR schema.
connect HR/HR; @?/rdbms/admin/dbmshptab.sql
This procedure starts hierarchical profiler data collection in the user's session.
Syntax
DBMS_HPROF.START_PROFILING ( location VARCHAR2 DEFAULT NULL, filename VARCHAR2 DEFAULT NULL, max_depth PLS_INTEGER DEFAULT NULL);
Parameters
Table 79-3 START_PROFILING Procedure Parameters
| Parameter | Description | 
|---|---|
| 
 | Name of a directory object. The file system directory mapped to this directory object is where the raw profiler output is generated. | 
| 
 | Output filename for the raw profiler data. The file is created in the directory specified by the  | 
| 
 | By default (that is, when  | 
Usage Notes
Even though the profiler does not individually track functions at depth greater than max_depth, the time spent in such functions is charged to the ancestor function at depth max_depth.
This procedure stops profiler data collection in the user's session. This subprogram also has the side effect of flushing data collected so far in the session, and it signals the end of a run.
Syntax
DBMS_HPROF.STOP_PROFILING;
Examples
Profiling with raw profiler data table
DECLARE
    analyze_runid number;
    trace_id number;
BEGIN
    -- create raw profiler data and analysis tables
    -- call create_tables with force_it =>FALSE (default) when
    -- raw profiler data and analysis tables do not exist already
    DBMS_HPROF.CREATE_TABLES;
    -- Start profiling
    -- Write raw profiler data in raw profiler data table
    trace_id := DBMS_HPROF.START_PROFILING;
    -- Run the procedure to be profiled
    test;
    -- Stop profiling
    DBMS_HPROF.STOP_PROFILING;
    -- analyzes trace_id entry in raw profiler data table and writes
    -- hierarchical profiler information in hprof’s analysis tables
    analyze_runid := DBMS_HPROF.ANALYZE(trace_id);
END;
/