DBMS_PROFILER v17
The DBMS_PROFILER
package collects and stores performance information about the PL/pgSQL and SPL statements that are executed during a performance profiling session. Use these functions and procedures to control the profiling tool.
Function/procedure | Return type | Description |
---|---|---|
FLUSH_DATA | Status Code or Exception | Flushes performance data collected in the current session without terminating the session. Profiling continues. |
GET_VERSION(major OUT, minor OUT) | n/a | Returns the version number of this package. |
INTERNAL_VERSION_CHECK | Status Code | Confirms that the current version of the profiler works with the current database. |
PAUSE_PROFILER | Status Code or Exception | Pauses data collection. |
RESUME_PROFILER | Status Code or Exception | Resumes data collection. |
START_PROFILER(run_comment, run_comment1 [, run_number OUT ]) | Status Code or Exception | Starts data collection. |
STOP_PROFILER | Status Code or Exception | Stops data collection and flushes performance data to the PLSQL_PROFILER_RAWDATA table. |
The functions in the DBMS_PROFILER
package return a status code to indicate success or failure. The DBMS_PROFILER
procedures raise an exception only if they encounter a failure. The table shows the status codes and messages returned by the functions and the exceptions raised by the procedures.
Status code | Message | Exception | Description |
---|---|---|---|
-1 | error version | version_mismatch | The profiler version and the database are incompatible. |
0 | success | n/a | The operation completed successfully. |
1 | error_param | profiler_error | The operation received an incorrect parameter. |
2 | error_io | profiler_error | The data flush operation failed. |
FLUSH_DATA
The FLUSH_DATA
function/procedure flushes the data collected in the current session without terminating the profiler session. The data is flushed to the tables described in the EDB Postgres Advanced Server Performance Features Guide. The function and procedure signatures are:
Parameters
status
Status code returned by the operation.
GET_VERSION
The GET_VERSION
procedure returns the version of DBMS_PROFILER
. The procedure signature is:
Parameters
major
The major version number of DBMS_PROFILER
.
minor
The minor version number of DBMS_PROFILER
.
INTERNAL_VERSION_CHECK
The INTERNAL_VERSION_CHECK
function confirms that the current version of DBMS_PROFILER
works with the current database. The function signature is:
Parameters
status
Status code returned by the operation.
PAUSE_PROFILER
The PAUSE_PROFILER
function/procedure pauses a profiling session. The function and procedure signatures are:
Parameters
status
Status code returned by the operation.
RESUME_PROFILER
The RESUME_PROFILER
function/procedure pauses a profiling session. The function and procedure signatures are:
Parameters
status
Status code returned by the operation.
START_PROFILER
The START_PROFILER
function/procedure starts a data collection session. The function and procedure signatures are:
Parameters
run_comment
A user-defined comment for the profiler session. The default value is SYSDATE
.
run_comment1
An additional user-defined comment for the profiler session. The default value is ''.
run_number
The session number of the profiler session.
status
Status code returned by the operation.
STOP_PROFILER
The STOP_PROFILER
function/procedure stops a profiling session and flushes the performance information to the DBMS_PROFILER
tables and view. The function and procedure signatures are:
Parameters
status
Status code returned by the operation.
Using DBMS_PROFILER
The DBMS_PROFILER
package collects and stores performance information about the PL/pgSQL and SPL statements that are executed during a profiling session. You can review the performance information in the tables and views provided by the profiler.
DBMS_PROFILER
works by recording a set of performance-related counters and timers for each line of PL/pgSQL or SPL statement that executes in a profiling session. The counters and timers are stored in a table named SYS.PLSQL_PROFILER_DATA
. When you complete a profiling session, DBMS_PROFILER
writes a row to the performance statistics table for each line of PL/pgSQL or SPL code that executed in the session. For example, suppose you execute the following function:
DBMS_PROFILER
adds one PLSQL_PROFILER_DATA
entry for each line of code in the getBalance()
function, including blank lines and comments. The entry corresponding to the SELECT
statement executed exactly one time and required a very small amount of time to execute. On the other hand, the entry corresponding to the RAISE INFO
statement executed once or not at all, depending on the value for the balance
column.
Some of the lines in this function contain no executable code so the performance statistics for those lines always contains zero values.
To start a profiling session, invoke the DBMS_PROFILER.START_PROFILER
function or procedure. Once you've invoked START_PROFILER
, EDB Postgres Advanced Server profiles every PL/pgSQL or SPL function, procedure, trigger, or anonymous block that your session executes until you either stop or pause the profiler by calling STOP_PROFILER
or PAUSE_PROFILER
.
Note
When you start or resume the profiler, the profiler gathers performance statistics only for functions/procedures/triggers that start after the call to START_PROFILER
(or RESUME_PROFILER
).
While the profiler is active, EDB Postgres Advanced Server records a large set of timers and counters in memory. When you invoke the STOP_PROFILER
or FLUSH_DATA
function/procedure, DBMS_PROFILER
writes those timers and counters to a set of three tables:
SYS.PLSQL_PROFILER_RAWDATA
Contains the performance counters and timers for each statement executed in the session.
SYS.PLSQL_PROFILER_RUNS
Contains a summary of each run, aggregating the information found in
PLSQL_PROFILER_RAWDATA
.SYS.PLSQL_PROFILER_UNITS
Contains a summary of each code unit (function, procedure, trigger, or anonymous block) executed in a session.
In addition, DBMS_PROFILER
defines a view, SYS.PLSQL_PROFILER_DATA
, which contains a subset of the PLSQL_PROFILER_RAWDATA
table.
A user who is not a superuser can gather profiling information but can't view that profiling information unless a superuser grants specific privileges on the profiling tables stored in the SYS
schema. This permits a nonprivileged user to gather performance statistics without exposing information that the administrator might want to keep secret.
Querying the DBMS_PROFILER tables and view
The following example uses DBMS_PROFILER
to retrieve performance information for procedures, functions, and triggers included in the sample data distributed with EDB Postgres Advanced Server.
- Open the EDB-PSQL command line, and establish a connection to the EDB Postgres Advanced Server database. Use an
EXEC
statement to start the profiling session:
Note
The call to start_profiler()
includes a comment that DBMS_PROFILER
associates with the profiler session.
- Call the
list_emp
function:
- Stop the profiling session with a call to
dbms_profiler.stop_profiler
:
- Start a new session with the
dbms_profiler.start_profiler
function followed by a new comment:
- Invoke the
get_dept_name
function:
- Execute an
UPDATE
statement that causes a trigger to execute:
- End the profiling session and flush the performance information to the profiling tables:
- Query the
plsql_profiler_runs
table to view a list of the profiling sessions, arranged byrunid:
- Query the
plsql_profiler_units
table to view the amount of time consumed by each unit (function, procedure, or trigger):
- Query the
plsql_profiler_rawdata
table to view a list of the wait-event counters and wait-event times:
- Query the
plsql_profiler_data
view to review a subset of the information found inplsql_profiler_rawdata
table:
DBMS_PROFILER reference
The EDB Postgres Advanced Server installer creates the following tables and views that you can query to review PL/SQL performance profile information:
Table name | Description |
---|---|
PLSQL_PROFILER_RUNS | Table containing information about all profiler runs, organized by runid . |
PLSQL_PROFILER_UNITS | Table containing information about all profiler runs, organized by unit. |
PLSQL_PROFILER_DATA | View containing performance statistics. |
PLSQL_PROFILER_RAWDATA | Table containing the performance statistics and the extended performance statistics for DRITA counters and timers. |
PLSQL_PROFILER_RUNS
The PLSQL_PROFILER_RUNS
table contains the following columns:
Column | Data type | Description |
---|---|---|
runid | INTEGER (NOT NULL) | Unique identifier (plsql_profiler_runnumber ) |
related_run | INTEGER | The runid of a related run |
run_owner | TEXT | The role that recorded the profiling session |
run_date | TIMESTAMP WITHOUT TIME ZONE | The profiling session start time |
run_comment | TEXT | User comments relevant to this run |
run_total_time | BIGINT | Run time (in microseconds) |
run_system_info | TEXT | Currently unused |
run_comment1 | TEXT | Additional user comments |
spare1 | TEXT | Currently unused |
PLSQL_PROFILER_UNITS
The PLSQL_PROFILER_UNITS
table contains the following columns:
Column | Data type | Description |
---|---|---|
runid | INTEGER | Unique identifier (plsql_profiler_runnumber ) |
unit_number | OID | Corresponds to the OID of the row in the pg_proc table that identifies the unit |
unit_type | TEXT | PL/SQL function, procedure, trigger or anonymous block |
unit_owner | TEXT | The identity of the role that owns the unit |
unit_name | TEXT | The complete signature of the unit |
unit_timestamp | TIMESTAMP WITHOUT TIME ZONE | Creation date of the unit (currently NULL) |
total_time | BIGINT | Time spent within the unit (in milliseconds) |
spare1 | BIGINT | Currently unused |
spare2 | BIGINT | Currently unused |
PLSQL_PROFILER_DATA
The PLSQL_PROFILER_DATA
view contains the following columns:
Column | Data type | Description |
---|---|---|
runid | INTEGER | Unique identifier (plsql_profiler_runnumber ) |
unit_number | OID | Object ID of the unit that contains the current line |
line# | INTEGER | Current line number of the profiled workload |
total_occur | BIGINT | The number of times that the line was executed |
total_time | DOUBLE PRECISION | The amount of time spent executing the line (in seconds) |
min_time | DOUBLE PRECISION | The minimum execution time for the line |
max_time | DOUBLE PRECISION | The maximum execution time for the line |
spare1 | NUMBER | Currently unused |
spare2 | NUMBER | Currently unused |
spare3 | NUMBER | Currently unused |
spare4 | NUMBER | Currently unused |
PLSQL_PROFILER_RAWDATA
The PLSQL_PROFILER_RAWDATA
table contains the statistical and wait-events information found in the PLSQL_PROFILER_DATA
view, as well as the performance statistics returned by the DRITA counters and timers.
Column | Data type | Description |
---|---|---|
runid | INTEGER | The run identifier (plsql_profiler_runnumber) . |
sourcecode | TEXT | The individual line of profiled code. |
func_oid | OID | Object ID of the unit that contains the current line. |
line_number | INTEGER | Current line number of the profiled workload. |
exec_count | BIGINT | The number of times that the line was executed. |
tuples_returned | BIGINT | Currently unused. |
time_total | DOUBLE PRECISION | The amount of time spent executing the line, in seconds. |
time_shortest | DOUBLE PRECISION | The minimum execution time for the line. |
time_longest | DOUBLE PRECISION | The maximum execution time for the line. |
num_scans | BIGINT | Currently unused. |
tuples_fetched | BIGINT | Currently unused. |
tuples_inserted | BIGINT | Currently unused. |
tuples_updated | BIGINT | Currently unused. |
tuples_deleted | BIGINT | Currently unused. |
blocks_fetched | BIGINT | Currently unused. |
blocks_hit | BIGINT | Currently unused. |
wal_write | BIGINT | A server has waited for a write to the write-ahead log buffer. Expect this value to be high. |
wal_flush | BIGINT | A server has waited for the write-ahead log to flush to disk. |
wal_file_sync | BIGINT | A server has waited for the write-ahead log to sync to disk (related to the wal_sync_method parameter which, by default, is 'fsync' - better performance can be gained by changing this parameter to open_sync ). |
db_file_read | BIGINT | A server has waited for the completion of a read (from disk). |
db_file_write | BIGINT | A server has waited for the completion of a write (to disk). |
db_file_sync | BIGINT | A server has waited for the operating system to flush all changes to disk. |
db_file_extend | BIGINT | A server has waited for the operating system while adding a new page to the end of a file. |
sql_parse | BIGINT | Currently unused. |
query_plan | BIGINT | A server has generated a query plan. |
other_lwlock_acquire | BIGINT | A server has waited for other light-weight lock to protect data. |
shared_plan_cache_collision | BIGINT | A server has waited for the completion of the shared_plan_cache_collision event. |
shared_plan_cache_insert | BIGINT | A server has waited for the completion of the shared_plan_cache_insert event. |
shared_plan_cache_hit | BIGINT | A server has waited for the completion of the shared_plan_cache_hit event. |
shared_plan_cache_miss | BIGINT | A server has waited for the completion of the shared_plan_cache_miss event. |
shared_plan_cache_lock | BIGINT | A server has waited for the completion of the shared_plan_cache_lock event. |
shared_plan_cache_busy | BIGINT | A server has waited for the completion of the shared_plan_cache_busy event. |
shmemindexlock | BIGINT | A server has waited to find or allocate space in the shared memory. |
oidgenlock | BIGINT | A server has waited to allocate or assign an OID. |
xidgenlock | BIGINT | A server has waited to allocate or assign a transaction ID. |
procarraylock | BIGINT | A server has waited to get a snapshot or clearing a transaction ID at transaction end. |
sinvalreadlock | BIGINT | A server has waited to retrieve or remove messages from shared invalidation queue. |
sinvalwritelock | BIGINT | A server has waited to add a message to the shared invalidation queue. |
walbufmappinglock | BIGINT | A server has waited to replace a page in WAL buffers. |
walwritelock | BIGINT | A server has waited for WAL buffers to be written to disk. |
controlfilelock | BIGINT | A server has waited to read or update the control file or creation of a new WAL file. |
checkpointlock | BIGINT | A server has waited to perform a checkpoint. |
clogcontrollock | BIGINT | A server has waited to read or update the transaction status. |
subtranscontrollock | BIGINT | A server has waited to read or update the sub-transaction information. |
multixactgenlock | BIGINT | A server has waited to read or update the shared multixact state. |
multixactoffsetcontrollock | BIGINT | A server has waited to read or update multixact offset mappings. |
multixactmembercontrollock | BIGINT | A server has waited to read or update multixact member mappings. |
relcacheinitlock | BIGINT | A server has waited to read or write the relation cache initialization file. |
checkpointercommlock | BIGINT | A server has waited to manage the fsync requests. |
twophasestatelock | BIGINT | A server has waited to read or update the state of prepared transactions. |
tablespacecreatelock | BIGINT | A server has waited to create or drop the tablespace. |
btreevacuumlock | BIGINT | A server has waited to read or update the vacuum related information for a B-tree index. |
addinshmeminitlock | BIGINT | A server has waited to manage space allocation in shared memory. |
autovacuumlock | BIGINT | The autovacuum launcher waiting to read or update the current state of autovacuum workers. |
autovacuumschedulelock | BIGINT | A server has waited to ensure that the table selected for a vacuum still needs vacuuming. |
syncscanlock | BIGINT | A server has waited to get the start location of a scan on a table for synchronized scans. |
relationmappinglock | BIGINT | A server has waited to update the relation map file used to store catalog to file node mapping. |
asyncctllock | BIGINT | A server has waited to read or update shared notification state. |
asyncqueuelock | BIGINT | A server has waited to read or update the notification messages. |
serializablexacthashlock | BIGINT | A server has waited to retrieve or store information about serializable transactions. |
serializablefinishedlistlock | BIGINT | A server has waited to access the list of finished serializable transactions. |
serializablepredicatelocklistlock | BIGINT | A server has waited to perform an operation on a list of locks held by serializable transactions. |
oldserxidlock | BIGINT | A server has waited to read or record the conflicting serializable transactions. |
syncreplock | BIGINT | A server has waited to read or update information about synchronous replicas. |
backgroundworkerlock | BIGINT | A server has waited to read or update the background worker state. |
dynamicsharedmemorycontrollock | BIGINT | A server has waited to read or update the dynamic shared memory state. |
autofilelock | BIGINT | A server has waited to update the postgresql.auto.conf file. |
replicationslotallocationlock | BIGINT | A server has waited to allocate or free a replication slot. |
replicationslotcontrollock | BIGINT | A server has waited to read or update replication slot state. |
committscontrollock | BIGINT | A server has waited to read or update transaction commit timestamps. |
committslock | BIGINT | A server has waited to read or update the last value set for the transaction timestamp. |
replicationoriginlock | BIGINT | A server has waited to set up, drop, or use replication origin. |
multixacttruncationlock | BIGINT | A server has waited to read or truncate multixact information. |
oldsnapshottimemaplock | BIGINT | A server has waited to read or update old snapshot control information. |
backendrandomlock | BIGINT | A server has waited to generate a random number. |
logicalrepworkerlock | BIGINT | A server has waited for the action on logical replication worker to finish. |
clogtruncationlock | BIGINT | A server has waited to truncate the write-ahead log or waiting for write-ahead log truncation to finish. |
bulkloadlock | BIGINT | A server has waited for the bulkloadlock to bulk upload the data. |
edbresourcemanagerlock | BIGINT | The edbresourcemanagerlock provides detail about edb resource manager lock module. |
wal_write_time | BIGINT | The amount of time that the server has waited for a wal_write wait event to write to the write-ahead log buffer (expect this value to be high). |
wal_flush_time | BIGINT | The amount of time that the server has waited for a wal_flush wait event to write-ahead log to flush to disk. |
wal_file_sync_time | BIGINT | The amount of time that the server has waited for a wal_file_sync wait event to write-ahead log to sync to disk (related to the wal_sync_method parameter which, by default, is 'fsync' - better performance can be gained by changing this parameter to open_sync). |
db_file_read_time | BIGINT | The amount of time that the server has waited for the db_file_read wait event for completion of a read (from disk). |
db_file_write_time | BIGINT | The amount of time that the server has waited for the db_file_write wait event for completion of a write (to disk). |
db_file_sync_time | BIGINT | The amount of time that the server has waited for the db_file_sync wait event to sync all changes to disk. |
db_file_extend_time | BIGINT | The amount of time that the server has waited for the db_file_extend wait event while adding a new page to the end of a file. |
sql_parse_time | BIGINT | The amount of time that the server has waited for the sql_parse wait event to parse a SQL statement. |
query_plan_time | BIGINT | The amount of time that the server has waited for the query_plan wait event to compute the execution plan for a SQL statement. |
other_lwlock_acquire_time | BIGINT | The amount of time that the server has waited for the other_lwlock_acquire wait event to protect data. |
shared_plan_cache_collision_time | BIGINT | The amount of time that the server has waited for the shared_plan_cache_collision wait event. |
shared_plan_cache_insert_time | BIGINT | The amount of time that the server has waited for the shared_plan_cache_insert wait event. |
shared_plan_cache_hit_time | BIGINT | The amount of time that the server has waited for the shared_plan_cache_hit wait event. |
shared_plan_cache_miss_time | BIGINT | The amount of time that the server has waited for the shared_plan_cache_miss wait event. |
shared_plan_cache_lock_time | BIGINT | The amount of time that the server has waited for the shared_plan_cache_lock wait event. |
shared_plan_cache_busy_time | BIGINT | The amount of time that the server has waited for the shared_plan_cache_busy wait event. |
shmemindexlock_time | BIGINT | The amount of time that the server has waited for the shmemindexlock wait event to find or allocate space in the shared memory. |
oidgenlock_time | BIGINT | The amount of time that the server has waited for the oidgenlock wait event to allocate or assign an OID. |
xidgenlock_time | BIGINT | The amount of time that the server has waited for xidgenlock wait event to allocate or assign a transaction ID. |
procarraylock_time | BIGINT | The amount of time that the server has waited for a procarraylock wait event to clear a transaction ID at transaction end. |
sinvalreadlock_time | BIGINT | The amount of time that the server has waited for a sinvalreadlock wait event to retrieve or remove messages from shared invalidation queue. |
sinvalwritelock_time | BIGINT | The amount of time that the server has waited for a sinvalwritelock wait event to add a message to the shared invalidation queue. |
walbufmappinglock_time | BIGINT | The amount of time that the server has waited for a walbufmappinglock wait event to replace a page in WAL buffers. |
walwritelock_time | BIGINT | The amount of time that the server has waited for a walwritelock wait event to write the WAL buffers to disk. |
controlfilelock_time | BIGINT | The amount of time that the server has waited for a controlfilelock wait event to read or update the control file or to create a new WAL file. |
checkpointlock_time | BIGINT | The amount of time that the server has waited for a checkpointlock wait event to perform a checkpoint. |
clogcontrollock_time | BIGINT | The amount of time that the server has waited for a clogcontrollock wait event to read or update the transaction status. |
subtranscontrollock_time | BIGINT | The amount of time that the server has waited for the subtranscontrollock wait event to read or update the sub-transaction information. |
multixactgenlock_time | BIGINT | The amount of time that the server has waited for the multixactgenlock wait event to read or update the shared multixact state. |
multixactoffsetcontrollock_time | BIGINT | The amount of time that the server has waited for the multixactoffsetcontrollock wait event to read or update multixact offset mappings. |
multixactmembercontrollock_time | BIGINT | The amount of time that the server has waited for the multixactmembercontrollock wait event to read or update multixact member mappings. |
relcacheinitlock_time | BIGINT | The amount of time that the server has waited for the relcacheinitlock wait event to read or write the relation cache initialization file. |
checkpointercommlock_time | BIGINT | The amount of time that the server has waited for the checkpointercommlock wait event to manage the fsync requests. |
twophasestatelock_time | BIGINT | The amount of time that the server has waited for the twophasestatelock wait event to read or update the state of prepared transactions. |
tablespacecreatelock_time | BIGINT | The amount of time that the server has waited for the tablespacecreatelock wait event to create or drop the tablespace. |
btreevacuumlock_time | BIGINT | The amount of time that the server has waited for the btreevacuumlock wait event to read or update the vacuum related information for a B-tree index. |
addinshmeminitlock_time | BIGINT | The amount of time that the server has waited for the addinshmeminitlock wait event to manage space allocation in shared memory. |
autovacuumlock_time | BIGINT | The amount of time that the server has waited for the autovacuumlock wait event to read or update the current state of autovacuum workers. |
autovacuumschedulelock_time | BIGINT | The amount of time that the server has waited for the autovacuumschedulelock wait event to ensure that the table selected for a vacuum still needs vacuuming. |
syncscanlock_time | BIGINT | The amount of time that the server has waited for the syncscanlock wait event to get the start location of a scan on a table for synchronized scans. |
relationmappinglock_time | BIGINT | The amount of time that the server has waited for the relationmappinglock wait event to update the relation map file used to store catalog to file node mapping. |
asyncctllock_time | BIGINT | The amount of time that the server has waited for the asyncctllock wait event to read or update shared notification state. |
asyncqueuelock_time | BIGINT | The amount of time that the server has waited for the asyncqueuelock wait event to read or update the notification messages. |
serializablexacthashlock_time | BIGINT | The amount of time that the server has waited for the serializablexacthashlock wait event to retrieve or store information about serializable transactions. |
serializablefinishedlistlock_time | BIGINT | The amount of time that the server has waited for the serializablefinishedlistlock wait event to access the list of finished serializable transactions. |
serializablepredicatelocklistlock_time | BIGINT | The amount of time that the server has waited for the serializablepredicatelocklistlock wait event to perform an operation on a list of locks held by serializable transactions. |
oldserxidlock_time | BIGINT | The amount of time that the server has waited for the oldserxidlock wait event to read or record the conflicting serializable transactions. |
syncreplock_time | BIGINT | The amount of time that the server has waited for the syncreplock wait event to read or update information about synchronous replicas. |
backgroundworkerlock_time | BIGINT | The amount of time that the server has waited for the backgroundworkerlock wait event to read or update the background worker state. |
dynamicsharedmemorycontrollock_time | BIGINT | The amount of time that the server has waited for the dynamicsharedmemorycontrollock wait event to read or update the dynamic shared memory state. |
autofilelock_time | BIGINT | The amount of time that the server has waited for the autofilelock wait event to update the postgresql.auto.conf file. |
replicationslotallocationlock_time | BIGINT | The amount of time that the server has waited for the replicationslotallocationlock wait event to allocate or free a replication slot. |
replicationslotcontrollock_time | BIGINT | The amount of time that the server has waited for the replicationslotcontrollock wait event to read or update replication slot state. |
committscontrollock_time | BIGINT | The amount of time that the server has waited for the committscontrollock wait event to read or update transaction commit timestamps. |
committslock_time | BIGINT | The amount of time that the server has waited for the committslock wait event to read or update the last value set for the transaction timestamp. |
replicationoriginlock_time | BIGINT | The amount of time that the server has waited for the replicationoriginlock wait event to set up, drop, or use replication origin. |
multixacttruncationlock_time | BIGINT | The amount of time that the server has waited for the multixacttruncationlock wait event to read or truncate multixact information. |
oldsnapshottimemaplock_time | BIGINT | The amount of time that the server has waited for the oldsnapshottimemaplock wait event to read or update old snapshot control information. |
backendrandomlock_time | BIGINT | The amount of time that the server has waited for the backendrandomlock wait event to generate a random number. |
logicalrepworkerlock_time | BIGINT | The amount of time that the server has waited for the logicalrepworkerlock wait event for an action on logical replication worker to finish. |
clogtruncationlock_time | BIGINT | The amount of time that the server has waited for the clogtruncationlock wait event to truncate the write-ahead log or waiting for write-ahead log truncation to finish. |
bulkloadlock_time | BIGINT | The amount of time that the server has waited for the bulkloadlock wait event to bulk upload the data. |
edbresourcemanagerlock_time | BIGINT | The amount of time that the server has waited for the edbresourcemanagerlock wait event. |
totalwaits | BIGINT | The total number of event waits. |
totalwaittime | BIGINT | The total time spent waiting for an event. |