Skip to content

Commit

Permalink
cleanup: sp_head::add_used_tables_to_table_list()
Browse files Browse the repository at this point in the history
Use TABLE::init_one_table(), don't duplicate it.
Put additional initializations into TABLE::init_one_table_for_prelocking()
  • Loading branch information
vuvova committed Dec 12, 2016
1 parent a3614d3 commit f136291
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 27 deletions.
33 changes: 6 additions & 27 deletions sql/sp_head.cc
Expand Up @@ -4256,7 +4256,7 @@ sp_head::add_used_tables_to_table_list(THD *thd,
if (stab->temp)
continue;

if (!(tab_buff= (char *)thd->calloc(ALIGN_SIZE(sizeof(TABLE_LIST)) *
if (!(tab_buff= (char *)thd->alloc(ALIGN_SIZE(sizeof(TABLE_LIST)) *
stab->lock_count)) ||
!(key_buff= (char*)thd->memdup(stab->qname.str,
stab->qname.length)))
Expand All @@ -4265,32 +4265,11 @@ sp_head::add_used_tables_to_table_list(THD *thd,
for (uint j= 0; j < stab->lock_count; j++)
{
table= (TABLE_LIST *)tab_buff;

table->db= key_buff;
table->db_length= stab->db_length;
table->table_name= table->db + table->db_length + 1;
table->table_name_length= stab->table_name_length;
table->alias= table->table_name + table->table_name_length + 1;
table->lock_type= stab->lock_type;
table->cacheable_table= 1;
table->prelocking_placeholder= 1;
table->belong_to_view= belong_to_view;
table->trg_event_map= stab->trg_event_map;
/*
Since we don't allow DDL on base tables in prelocked mode it
is safe to infer the type of metadata lock from the type of
table lock.
*/
table->mdl_request.init(MDL_key::TABLE, table->db, table->table_name,
table->lock_type >= TL_WRITE_ALLOW_WRITE ?
MDL_SHARED_WRITE : MDL_SHARED_READ,
MDL_TRANSACTION);

/* Everyting else should be zeroed */

**query_tables_last_ptr= table;
table->prev_global= *query_tables_last_ptr;
*query_tables_last_ptr= &table->next_global;
table->init_one_table_for_prelocking(key_buff, stab->db_length,
key_buff + stab->db_length + 1, stab->table_name_length,
key_buff + stab->db_length + stab->table_name_length + 2,
stab->lock_type, belong_to_view, stab->trg_event_map,
query_tables_last_ptr);

tab_buff+= ALIGN_SIZE(sizeof(TABLE_LIST));
result= TRUE;
Expand Down
22 changes: 22 additions & 0 deletions sql/table.h
Expand Up @@ -1757,6 +1757,28 @@ struct TABLE_LIST
MDL_TRANSACTION);
}

inline void init_one_table_for_prelocking(const char *db_name_arg,
size_t db_length_arg,
const char *table_name_arg,
size_t table_name_length_arg,
const char *alias_arg,
enum thr_lock_type lock_type_arg,
TABLE_LIST *belong_to_view_arg,
uint8 trg_event_map_arg,
TABLE_LIST ***last_ptr)
{
init_one_table(db_name_arg, db_length_arg, table_name_arg,
table_name_length_arg, alias_arg, lock_type_arg);
cacheable_table= 1;
prelocking_placeholder= 1;
belong_to_view= belong_to_view_arg;
trg_event_map= trg_event_map_arg;

**last_ptr= this;
prev_global= *last_ptr;
*last_ptr= &next_global;
}

/*
List of tables local to a subquery (used by SQL_I_List). Considers
views as leaves (unlike 'next_leaf' below). Created at parse time
Expand Down

0 comments on commit f136291

Please sign in to comment.