Commit 85b6ef6d authored by vasil's avatar vasil

branches/zip:

Change the format of TRX_IDs in INFORMATION_SCHEMA tables from DEC to
HEX.

The current TRX_IDs are hard to remember and track down: 426355, 428466,
428566, etc.

In HEX:
* there are less "digits", the strings are shorter;
* since there are 16 instead of 10 "digits", the chance of having
  repeating ones are smaller.

The above look like 68173, 689B2, 68A16 in HEX.

Discussed with:	Ken
Approved by:	Heikki (via IM)
parent 1ae59d9e
...@@ -190,10 +190,10 @@ static ST_FIELD_INFO innodb_trx_fields_info[] = ...@@ -190,10 +190,10 @@ static ST_FIELD_INFO innodb_trx_fields_info[] =
{ {
#define IDX_TRX_ID 0 #define IDX_TRX_ID 0
{STRUCT_FLD(field_name, "trx_id"), {STRUCT_FLD(field_name, "trx_id"),
STRUCT_FLD(field_length, MY_INT64_NUM_DECIMAL_DIGITS), STRUCT_FLD(field_length, TRX_ID_MAX_LEN + 1),
STRUCT_FLD(field_type, MYSQL_TYPE_LONGLONG), STRUCT_FLD(field_type, MYSQL_TYPE_STRING),
STRUCT_FLD(value, 0), STRUCT_FLD(value, 0),
STRUCT_FLD(field_flags, MY_I_S_UNSIGNED), STRUCT_FLD(field_flags, 0),
STRUCT_FLD(old_name, ""), STRUCT_FLD(old_name, ""),
STRUCT_FLD(open_method, SKIP_OPEN_TABLE)}, STRUCT_FLD(open_method, SKIP_OPEN_TABLE)},
...@@ -291,13 +291,15 @@ fill_innodb_trx_from_cache( ...@@ -291,13 +291,15 @@ fill_innodb_trx_from_cache(
for (i = 0; i < rows_num; i++) { for (i = 0; i < rows_num; i++) {
i_s_trx_row_t* row; i_s_trx_row_t* row;
char trx_id[TRX_ID_MAX_LEN + 1];
row = (i_s_trx_row_t*) row = (i_s_trx_row_t*)
trx_i_s_cache_get_nth_row( trx_i_s_cache_get_nth_row(
cache, I_S_INNODB_TRX, i); cache, I_S_INNODB_TRX, i);
/* trx_id */ /* trx_id */
OK(fields[IDX_TRX_ID]->store(row->trx_id)); ut_snprintf(trx_id, sizeof(trx_id), TRX_ID_FMT, row->trx_id);
OK(field_store_string(fields[IDX_TRX_ID], trx_id));
/* trx_weight */ /* trx_weight */
OK(fields[IDX_TRX_WEIGHT]->store(row->trx_weight)); OK(fields[IDX_TRX_WEIGHT]->store(row->trx_weight));
...@@ -434,10 +436,10 @@ static ST_FIELD_INFO innodb_locks_fields_info[] = ...@@ -434,10 +436,10 @@ static ST_FIELD_INFO innodb_locks_fields_info[] =
#define IDX_LOCK_TRX_ID 1 #define IDX_LOCK_TRX_ID 1
{STRUCT_FLD(field_name, "lock_trx_id"), {STRUCT_FLD(field_name, "lock_trx_id"),
STRUCT_FLD(field_length, MY_INT64_NUM_DECIMAL_DIGITS), STRUCT_FLD(field_length, TRX_ID_MAX_LEN + 1),
STRUCT_FLD(field_type, MYSQL_TYPE_LONGLONG), STRUCT_FLD(field_type, MYSQL_TYPE_STRING),
STRUCT_FLD(value, 0), STRUCT_FLD(value, 0),
STRUCT_FLD(field_flags, MY_I_S_UNSIGNED), STRUCT_FLD(field_flags, 0),
STRUCT_FLD(old_name, ""), STRUCT_FLD(old_name, ""),
STRUCT_FLD(open_method, SKIP_OPEN_TABLE)}, STRUCT_FLD(open_method, SKIP_OPEN_TABLE)},
...@@ -556,6 +558,8 @@ fill_innodb_locks_from_cache( ...@@ -556,6 +558,8 @@ fill_innodb_locks_from_cache(
char buf[2 * NAME_LEN + 14]; char buf[2 * NAME_LEN + 14];
const char* bufend; const char* bufend;
char lock_trx_id[TRX_ID_MAX_LEN + 1];
row = (i_s_locks_row_t*) row = (i_s_locks_row_t*)
trx_i_s_cache_get_nth_row( trx_i_s_cache_get_nth_row(
cache, I_S_INNODB_LOCKS, i); cache, I_S_INNODB_LOCKS, i);
...@@ -566,7 +570,9 @@ fill_innodb_locks_from_cache( ...@@ -566,7 +570,9 @@ fill_innodb_locks_from_cache(
lock_id)); lock_id));
/* lock_trx_id */ /* lock_trx_id */
OK(fields[IDX_LOCK_TRX_ID]->store(row->lock_trx_id)); ut_snprintf(lock_trx_id, sizeof(lock_trx_id),
TRX_ID_FMT, row->lock_trx_id);
OK(field_store_string(fields[IDX_LOCK_TRX_ID], lock_trx_id));
/* lock_mode */ /* lock_mode */
OK(field_store_string(fields[IDX_LOCK_MODE], OK(field_store_string(fields[IDX_LOCK_MODE],
...@@ -696,10 +702,10 @@ static ST_FIELD_INFO innodb_lock_waits_fields_info[] = ...@@ -696,10 +702,10 @@ static ST_FIELD_INFO innodb_lock_waits_fields_info[] =
{ {
#define IDX_REQUESTING_TRX_ID 0 #define IDX_REQUESTING_TRX_ID 0
{STRUCT_FLD(field_name, "requesting_trx_id"), {STRUCT_FLD(field_name, "requesting_trx_id"),
STRUCT_FLD(field_length, MY_INT64_NUM_DECIMAL_DIGITS), STRUCT_FLD(field_length, TRX_ID_MAX_LEN + 1),
STRUCT_FLD(field_type, MYSQL_TYPE_LONGLONG), STRUCT_FLD(field_type, MYSQL_TYPE_STRING),
STRUCT_FLD(value, 0), STRUCT_FLD(value, 0),
STRUCT_FLD(field_flags, MY_I_S_UNSIGNED), STRUCT_FLD(field_flags, 0),
STRUCT_FLD(old_name, ""), STRUCT_FLD(old_name, ""),
STRUCT_FLD(open_method, SKIP_OPEN_TABLE)}, STRUCT_FLD(open_method, SKIP_OPEN_TABLE)},
...@@ -714,10 +720,10 @@ static ST_FIELD_INFO innodb_lock_waits_fields_info[] = ...@@ -714,10 +720,10 @@ static ST_FIELD_INFO innodb_lock_waits_fields_info[] =
#define IDX_BLOCKING_TRX_ID 2 #define IDX_BLOCKING_TRX_ID 2
{STRUCT_FLD(field_name, "blocking_trx_id"), {STRUCT_FLD(field_name, "blocking_trx_id"),
STRUCT_FLD(field_length, MY_INT64_NUM_DECIMAL_DIGITS), STRUCT_FLD(field_length, TRX_ID_MAX_LEN + 1),
STRUCT_FLD(field_type, MYSQL_TYPE_LONGLONG), STRUCT_FLD(field_type, MYSQL_TYPE_STRING),
STRUCT_FLD(value, 0), STRUCT_FLD(value, 0),
STRUCT_FLD(field_flags, MY_I_S_UNSIGNED), STRUCT_FLD(field_flags, 0),
STRUCT_FLD(old_name, ""), STRUCT_FLD(old_name, ""),
STRUCT_FLD(open_method, SKIP_OPEN_TABLE)}, STRUCT_FLD(open_method, SKIP_OPEN_TABLE)},
...@@ -763,13 +769,18 @@ fill_innodb_lock_waits_from_cache( ...@@ -763,13 +769,18 @@ fill_innodb_lock_waits_from_cache(
i_s_lock_waits_row_t* row; i_s_lock_waits_row_t* row;
char requesting_trx_id[TRX_ID_MAX_LEN + 1];
char blocking_trx_id[TRX_ID_MAX_LEN + 1];
row = (i_s_lock_waits_row_t*) row = (i_s_lock_waits_row_t*)
trx_i_s_cache_get_nth_row( trx_i_s_cache_get_nth_row(
cache, I_S_INNODB_LOCK_WAITS, i); cache, I_S_INNODB_LOCK_WAITS, i);
/* requesting_trx_id */ /* requesting_trx_id */
OK(fields[IDX_REQUESTING_TRX_ID]->store( ut_snprintf(requesting_trx_id, sizeof(requesting_trx_id),
row->requested_lock_row->lock_trx_id)); TRX_ID_FMT, row->requested_lock_row->lock_trx_id);
OK(field_store_string(fields[IDX_REQUESTING_TRX_ID],
requesting_trx_id));
/* requested_lock_id */ /* requested_lock_id */
OK(field_store_string( OK(field_store_string(
...@@ -780,8 +791,10 @@ fill_innodb_lock_waits_from_cache( ...@@ -780,8 +791,10 @@ fill_innodb_lock_waits_from_cache(
sizeof(requested_lock_id)))); sizeof(requested_lock_id))));
/* blocking_trx_id */ /* blocking_trx_id */
OK(fields[IDX_BLOCKING_TRX_ID]->store( ut_snprintf(blocking_trx_id, sizeof(blocking_trx_id),
row->blocking_lock_row->lock_trx_id)); TRX_ID_FMT, row->blocking_lock_row->lock_trx_id);
OK(field_store_string(fields[IDX_BLOCKING_TRX_ID],
blocking_trx_id));
/* blocking_lock_id */ /* blocking_lock_id */
OK(field_store_string( OK(field_store_string(
......
...@@ -12,6 +12,7 @@ Created July 17, 2007 Vasil Dimov ...@@ -12,6 +12,7 @@ Created July 17, 2007 Vasil Dimov
#define trx0i_s_h #define trx0i_s_h
#include "univ.i" #include "univ.i"
#include "trx0types.h"
#include "ut0ut.h" #include "ut0ut.h"
/* the maximum amount of memory that can be consumed by innodb_trx, /* the maximum amount of memory that can be consumed by innodb_trx,
...@@ -174,8 +175,8 @@ trx_i_s_cache_is_truncated( ...@@ -174,8 +175,8 @@ trx_i_s_cache_is_truncated(
/* The maximum length of a resulting lock_id_size in /* The maximum length of a resulting lock_id_size in
trx_i_s_create_lock_id(), not including the terminating '\0'. trx_i_s_create_lock_id(), not including the terminating '\0'.
"%llu:%lu:%lu:%lu" -> 83 chars */ ":%lu:%lu:%lu" -> 63 chars */
#define TRX_I_S_LOCK_ID_MAX_LEN 83 #define TRX_I_S_LOCK_ID_MAX_LEN (TRX_ID_MAX_LEN + 63)
/*********************************************************************** /***********************************************************************
Crafts a lock id string from a i_s_locks_row_t object. Returns its Crafts a lock id string from a i_s_locks_row_t object. Returns its
......
...@@ -18,6 +18,10 @@ Created 3/26/1996 Heikki Tuuri ...@@ -18,6 +18,10 @@ Created 3/26/1996 Heikki Tuuri
/* printf(3) format used for printing TRX_ID_PRINTF_PREP() */ /* printf(3) format used for printing TRX_ID_PRINTF_PREP() */
#define TRX_ID_FMT "%llX" #define TRX_ID_FMT "%llX"
/* maximum length that a formatted trx_t::id could take, not including
the terminating '\0'. */
#define TRX_ID_MAX_LEN 17
/* Memory objects */ /* Memory objects */
typedef struct trx_struct trx_t; typedef struct trx_struct trx_t;
typedef struct trx_sys_struct trx_sys_t; typedef struct trx_sys_struct trx_sys_t;
......
...@@ -1379,13 +1379,13 @@ trx_i_s_create_lock_id( ...@@ -1379,13 +1379,13 @@ trx_i_s_create_lock_id(
if (row->lock_space != ULINT_UNDEFINED) { if (row->lock_space != ULINT_UNDEFINED) {
/* record lock */ /* record lock */
res_len = ut_snprintf(lock_id, lock_id_size, res_len = ut_snprintf(lock_id, lock_id_size,
"%llu:%lu:%lu:%lu", TRX_ID_FMT ":%lu:%lu:%lu",
row->lock_trx_id, row->lock_space, row->lock_trx_id, row->lock_space,
row->lock_page, row->lock_rec); row->lock_page, row->lock_rec);
} else { } else {
/* table lock */ /* table lock */
res_len = ut_snprintf(lock_id, lock_id_size, res_len = ut_snprintf(lock_id, lock_id_size,
"%llu:%llu", TRX_ID_FMT ":%llu",
row->lock_trx_id, row->lock_trx_id,
row->lock_table_id); row->lock_table_id);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment