Change internal plan ID type from uint64 to int64
uint64 was chosen to be consistent with the type used by the query ID, but the conclusion of a recent discussion for the query ID is that int64 is a better fit as the signed form is shown to the user, for PGSS or EXPLAIN outputs. This commit changes the plan ID to use int64, following c3eda50b0648 that has done the same for the query ID. The plan ID is new to v18, introduced in 2a0cd38da5cc. Author: Michael Paquier <michael@paquier.xyz> Reviewed-by: Sami Imseih <samimseih@gmail.com> Discussion: https://postgr.es/m/aCvzJNwetyEI3Sgo@paquier.xyz
This commit is contained in:
parent
706054b11b
commit
e050af2868
@ -2034,7 +2034,7 @@ exec_bind_message(StringInfo input_message)
|
|||||||
{
|
{
|
||||||
PlannedStmt *plan = lfirst_node(PlannedStmt, lc);
|
PlannedStmt *plan = lfirst_node(PlannedStmt, lc);
|
||||||
|
|
||||||
if (plan->planId != UINT64CONST(0))
|
if (plan->planId != INT64CONST(0))
|
||||||
{
|
{
|
||||||
pgstat_report_plan_id(plan->planId, false);
|
pgstat_report_plan_id(plan->planId, false);
|
||||||
break;
|
break;
|
||||||
@ -2185,7 +2185,7 @@ exec_execute_message(const char *portal_name, long max_rows)
|
|||||||
{
|
{
|
||||||
PlannedStmt *stmt = lfirst_node(PlannedStmt, lc);
|
PlannedStmt *stmt = lfirst_node(PlannedStmt, lc);
|
||||||
|
|
||||||
if (stmt->planId != UINT64CONST(0))
|
if (stmt->planId != INT64CONST(0))
|
||||||
{
|
{
|
||||||
pgstat_report_plan_id(stmt->planId, false);
|
pgstat_report_plan_id(stmt->planId, false);
|
||||||
break;
|
break;
|
||||||
|
@ -321,7 +321,7 @@ pgstat_bestart_initial(void)
|
|||||||
lbeentry.st_progress_command = PROGRESS_COMMAND_INVALID;
|
lbeentry.st_progress_command = PROGRESS_COMMAND_INVALID;
|
||||||
lbeentry.st_progress_command_target = InvalidOid;
|
lbeentry.st_progress_command_target = InvalidOid;
|
||||||
lbeentry.st_query_id = INT64CONST(0);
|
lbeentry.st_query_id = INT64CONST(0);
|
||||||
lbeentry.st_plan_id = UINT64CONST(0);
|
lbeentry.st_plan_id = INT64CONST(0);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* we don't zero st_progress_param here to save cycles; nobody should
|
* we don't zero st_progress_param here to save cycles; nobody should
|
||||||
@ -600,7 +600,7 @@ pgstat_report_activity(BackendState state, const char *cmd_str)
|
|||||||
/* st_xact_start_timestamp and wait_event_info are also disabled */
|
/* st_xact_start_timestamp and wait_event_info are also disabled */
|
||||||
beentry->st_xact_start_timestamp = 0;
|
beentry->st_xact_start_timestamp = 0;
|
||||||
beentry->st_query_id = INT64CONST(0);
|
beentry->st_query_id = INT64CONST(0);
|
||||||
beentry->st_plan_id = UINT64CONST(0);
|
beentry->st_plan_id = INT64CONST(0);
|
||||||
proc->wait_event_info = 0;
|
proc->wait_event_info = 0;
|
||||||
PGSTAT_END_WRITE_ACTIVITY(beentry);
|
PGSTAT_END_WRITE_ACTIVITY(beentry);
|
||||||
}
|
}
|
||||||
@ -663,7 +663,7 @@ pgstat_report_activity(BackendState state, const char *cmd_str)
|
|||||||
if (state == STATE_RUNNING)
|
if (state == STATE_RUNNING)
|
||||||
{
|
{
|
||||||
beentry->st_query_id = INT64CONST(0);
|
beentry->st_query_id = INT64CONST(0);
|
||||||
beentry->st_plan_id = UINT64CONST(0);
|
beentry->st_plan_id = INT64CONST(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cmd_str != NULL)
|
if (cmd_str != NULL)
|
||||||
@ -722,7 +722,7 @@ pgstat_report_query_id(int64 query_id, bool force)
|
|||||||
* --------
|
* --------
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
pgstat_report_plan_id(uint64 plan_id, bool force)
|
pgstat_report_plan_id(int64 plan_id, bool force)
|
||||||
{
|
{
|
||||||
volatile PgBackendStatus *beentry = MyBEEntry;
|
volatile PgBackendStatus *beentry = MyBEEntry;
|
||||||
|
|
||||||
@ -1154,7 +1154,7 @@ pgstat_get_my_query_id(void)
|
|||||||
*
|
*
|
||||||
* Return current backend's plan identifier.
|
* Return current backend's plan identifier.
|
||||||
*/
|
*/
|
||||||
uint64
|
int64
|
||||||
pgstat_get_my_plan_id(void)
|
pgstat_get_my_plan_id(void)
|
||||||
{
|
{
|
||||||
if (!MyBEEntry)
|
if (!MyBEEntry)
|
||||||
|
@ -56,7 +56,7 @@ typedef struct PlannedStmt
|
|||||||
int64 queryId;
|
int64 queryId;
|
||||||
|
|
||||||
/* plan identifier (can be set by plugins) */
|
/* plan identifier (can be set by plugins) */
|
||||||
uint64 planId;
|
int64 planId;
|
||||||
|
|
||||||
/* is it insert|update|delete|merge RETURNING? */
|
/* is it insert|update|delete|merge RETURNING? */
|
||||||
bool hasReturning;
|
bool hasReturning;
|
||||||
|
@ -173,7 +173,7 @@ typedef struct PgBackendStatus
|
|||||||
int64 st_query_id;
|
int64 st_query_id;
|
||||||
|
|
||||||
/* plan identifier, optionally computed using planner_hook */
|
/* plan identifier, optionally computed using planner_hook */
|
||||||
uint64 st_plan_id;
|
int64 st_plan_id;
|
||||||
} PgBackendStatus;
|
} PgBackendStatus;
|
||||||
|
|
||||||
|
|
||||||
@ -322,7 +322,7 @@ extern void pgstat_clear_backend_activity_snapshot(void);
|
|||||||
/* Activity reporting functions */
|
/* Activity reporting functions */
|
||||||
extern void pgstat_report_activity(BackendState state, const char *cmd_str);
|
extern void pgstat_report_activity(BackendState state, const char *cmd_str);
|
||||||
extern void pgstat_report_query_id(int64 query_id, bool force);
|
extern void pgstat_report_query_id(int64 query_id, bool force);
|
||||||
extern void pgstat_report_plan_id(uint64 plan_id, bool force);
|
extern void pgstat_report_plan_id(int64 plan_id, bool force);
|
||||||
extern void pgstat_report_tempfile(size_t filesize);
|
extern void pgstat_report_tempfile(size_t filesize);
|
||||||
extern void pgstat_report_appname(const char *appname);
|
extern void pgstat_report_appname(const char *appname);
|
||||||
extern void pgstat_report_xact_timestamp(TimestampTz tstamp);
|
extern void pgstat_report_xact_timestamp(TimestampTz tstamp);
|
||||||
@ -330,7 +330,7 @@ extern const char *pgstat_get_backend_current_activity(int pid, bool checkUser);
|
|||||||
extern const char *pgstat_get_crashed_backend_activity(int pid, char *buffer,
|
extern const char *pgstat_get_crashed_backend_activity(int pid, char *buffer,
|
||||||
int buflen);
|
int buflen);
|
||||||
extern int64 pgstat_get_my_query_id(void);
|
extern int64 pgstat_get_my_query_id(void);
|
||||||
extern uint64 pgstat_get_my_plan_id(void);
|
extern int64 pgstat_get_my_plan_id(void);
|
||||||
extern BackendType pgstat_get_backend_type_by_proc_number(ProcNumber procNumber);
|
extern BackendType pgstat_get_backend_type_by_proc_number(ProcNumber procNumber);
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user