summaryrefslogtreecommitdiff
path: root/sql
diff options
context:
space:
mode:
Diffstat (limited to 'sql')
-rw-r--r--sql/sp_head.cc33
-rw-r--r--sql/table.h22
2 files changed, 28 insertions, 27 deletions
diff --git a/sql/sp_head.cc b/sql/sp_head.cc
index 37e449cd666..c9c83d6ef22 100644
--- a/sql/sp_head.cc
+++ b/sql/sp_head.cc
@@ -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)))
@@ -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;
diff --git a/sql/table.h b/sql/table.h
index 9ed65a3e434..ae2a94d00ca 100644
--- a/sql/table.h
+++ b/sql/table.h
@@ -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