STATEMENT_HISTORY
Displays information about statements executed on the current node. To query this system catalog, you must have the SYSADMIN permission. The result can be queried only in the system database but cannot be queried in the user database.
- Data must be queried in the Postgres database. No data exists in other databases.
- This system catalog is controlled by track_stmt_stat_level. The default value is OFF,L0, where the first part controls full SQL statements, and the second part controls slow SQL statements. For details about the record level of each field, see the following table.
- For slow SQL statements, if the value of track_stmt_stat_level is not OFF and the SQL execution time exceeds the value of log_min_duration_statement, the SQL statement is recorded as a slow SQL statement.
| Name | Type | Description | Record Level | 
|---|---|---|---|
| db_name | name | Database name. | L0 | 
| schema_name | name | Schema name. | L0 | 
| origin_node | integer | Node name. | L0 | 
| user_name | name | Username. | L0 | 
| application_name | text | Name of the application that sends a request. | L0 | 
| client_addr | text | IP address of the client that sends a request. | L0 | 
| client_port | integer | Port number of the client that sends a request. | L0 | 
| unique_query_id | bigint | ID of the normalized SQL statement. | L0 | 
| debug_query_id | bigint | ID of the unique SQL statement. | L0 | 
| query | text | Normalized SQL (available only on CNs). | L0 | 
| start_time | timestamp with time zone | Time when a statement starts. | L0 | 
| finish_time | timestamp with time zone | Time when a statement ends. | L0 | 
| slow_sql_threshold | bigint | Standard for slow SQL statement execution. | L0 | 
| transaction_id | bigint | Transaction ID. | L0 | 
| thread_id | bigint | ID of an execution thread. | L0 | 
| session_id | bigint | Session ID of a user. | L0 | 
| n_soft_parse | bigint | Number of soft parsing times. The value can be n_soft_parse + n_hard_parse and can be greater than n_calls because the subquery is not counted in n_calls. | L0 | 
| n_hard_parse | bigint | Number of hard parsing times. The value can be n_soft_parse + n_hard_parse and can be greater than n_calls because the subquery is not counted in n_calls. | L0 | 
| query_plan | text | Statement execution plan. | L1 | 
| n_returned_rows | bigint | Number of rows in the result set returned by the SELECT statement. | L0 | 
| n_tuples_fetched | bigint | Number of rows randomly scanned. | L0 | 
| n_tuples_returned | bigint | Number of rows sequentially scanned. | L0 | 
| n_tuples_inserted | bigint | Number of rows inserted. | L0 | 
| n_tuples_updated | bigint | Number of rows updated. | L0 | 
| n_tuples_deleted | bigint | Number of rows deleted. | L0 | 
| n_blocks_fetched | bigint | Number of buffer block access times. | L0 | 
| n_blocks_hit | bigint | Number of buffer block hits. | L0 | 
| db_time | bigint | Valid DB time, which is accumulated if multiple threads are involved (unit: μs). | L0 | 
| cpu_time | bigint | CPU time (unit: μs). | L0 | 
| execution_time | bigint | Execution time in the executor (unit: μs). | L0 | 
| parse_time | bigint | SQL parsing time (unit: μs). | L0 | 
| plan_time | bigint | SQL plan generation time (unit: μs). | L0 | 
| rewrite_time | bigint | SQL rewriting time (unit: μs). | L0 | 
| pl_execution_time | bigint | Execution time of PL/pgSQL (unit: μs). | L0 | 
| pl_compilation_time | bigint | Compilation time of PL/pgSQL (unit: μs). | L0 | 
| data_io_time | bigint | I/O time (unit: μs). | L0 | 
| net_send_info | text | Network status of messages sent through a physical connection, including the time (unit: μs), number of calls, and throughput (unit: byte). In a distributed database, CNs communicate with each other, CNs communicate with the client, and CNs communicate with DNs through physical connections. This column can be used to analyze the network overhead of SQL statements in a distributed system. Example: {"time":xxx, "n_calls":xxx, "size":xxx}. | L0 | 
| net_recv_info | text | Network status of messages received through a physical connection, including the time (unit: μs), number of calls, and throughput (unit: byte). In a distributed database, CNs communicate with each other, CNs communicate with the client, and CNs communicate with DNs through physical connections. This column can be used to analyze the network overhead of SQL statements in a distributed system. Example: {"time":xxx, "n_calls":xxx, "size":xxx}. | L0 | 
| net_stream_send_info | text | Network status of messages sent through a logical connection, including the time (unit: μs), number of calls, and throughput (unit: byte). In a distributed database, DNs of different shards communicate with each other through logical connections. This column can be used to analyze the network overhead of SQL statements in a distributed system. Example: {"time":xxx, "n_calls":xxx, "size":xxx}. | L0 | 
| net_stream_recv_info | text | Network status of messages received through a logical connection, including the time (unit: μs), number of calls, and throughput (unit: byte). In a distributed database, DNs of different shards communicate with each other through logical connections. This column can be used to analyze the network overhead of SQL statements in a distributed system. Example: {"time":xxx, "n_calls":xxx, "size":xxx}. | L0 | 
| lock_count | bigint | Number of locks. | L0 | 
| lock_time | bigint | Time required for locking. | L1 | 
| lock_wait_count | bigint | Number of lock waits. | L0 | 
| lock_wait_time | bigint | Time required for lock waiting. | L1 | 
| lock_max_count | bigint | Maximum number of locks. | L0 | 
| lwlock_count | bigint | Number of lightweight locks (reserved). | L0 | 
| lwlock_wait_count | bigint | Number of lightweight lock waits. | L0 | 
| lwlock_time | bigint | Time required for lightweight locking (reserved). | L1 | 
| lwlock_wait_time | bigint | Time required for lightweight lock waiting. | L1 | 
| details | bytea | List of statement lock events, which are recorded in chronological order. The number of records is affected by the track_stmt_details_size parameter. This column is binary and needs to be read using the parsing function pg_catalog.statement_detail_decode. For details, see Table 8. Events include: 
 | L2 | 
| is_slow_sql | Boolean | Specifies whether the SQL statement is a slow SQL statement. 
 | L0 | 
| trace_id | text | Driver-specific trace ID, which is associated with an application request. | L0 | 
| advise | text | Risks which may cause slow SQL statements. (Multiple risks may exist at the same time.) 
 | L0 | 
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.
 
    