Commit 3b365fa8 authored by Sergei Golubchik's avatar Sergei Golubchik

cleanup: sp_head::add_used_tables_to_table_list()

Use TABLE::init_one_table(), don't duplicate it.
Put additional initializations into TABLE::init_one_table_for_prelocking()

Backport of f1362910
parent 22bcfa01
...@@ -4219,7 +4219,7 @@ sp_head::add_used_tables_to_table_list(THD *thd, ...@@ -4219,7 +4219,7 @@ sp_head::add_used_tables_to_table_list(THD *thd,
if (stab->temp) if (stab->temp)
continue; 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)) || stab->lock_count)) ||
!(key_buff= (char*)thd->memdup(stab->qname.str, !(key_buff= (char*)thd->memdup(stab->qname.str,
stab->qname.length))) stab->qname.length)))
...@@ -4228,32 +4228,11 @@ sp_head::add_used_tables_to_table_list(THD *thd, ...@@ -4228,32 +4228,11 @@ sp_head::add_used_tables_to_table_list(THD *thd,
for (uint j= 0; j < stab->lock_count; j++) for (uint j= 0; j < stab->lock_count; j++)
{ {
table= (TABLE_LIST *)tab_buff; table= (TABLE_LIST *)tab_buff;
table->init_one_table_for_prelocking(key_buff, stab->db_length,
table->db= key_buff; key_buff + stab->db_length + 1, stab->table_name_length,
table->db_length= stab->db_length; key_buff + stab->db_length + stab->table_name_length + 2,
table->table_name= table->db + table->db_length + 1; stab->lock_type, belong_to_view, stab->trg_event_map,
table->table_name_length= stab->table_name_length; query_tables_last_ptr);
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;
tab_buff+= ALIGN_SIZE(sizeof(TABLE_LIST)); tab_buff+= ALIGN_SIZE(sizeof(TABLE_LIST));
result= TRUE; result= TRUE;
......
...@@ -1707,6 +1707,28 @@ struct TABLE_LIST ...@@ -1707,6 +1707,28 @@ struct TABLE_LIST
MDL_TRANSACTION); 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 List of tables local to a subquery (used by SQL_I_List). Considers
views as leaves (unlike 'next_leaf' below). Created at parse time views as leaves (unlike 'next_leaf' below). Created at parse time
......
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