diff options
-rw-r--r-- | sql/partition_info.cc | 31 | ||||
-rw-r--r-- | sql/sql_base.cc | 26 | ||||
-rw-r--r-- | sql/sql_table.cc | 4 | ||||
-rw-r--r-- | sql/vtmd.cc | 6 |
4 files changed, 36 insertions, 31 deletions
diff --git a/sql/partition_info.cc b/sql/partition_info.cc index da34a4dbf0f..dacb8e32353 100644 --- a/sql/partition_info.cc +++ b/sql/partition_info.cc @@ -856,21 +856,6 @@ bool partition_info::has_unique_name(partition_element *element) DBUG_RETURN(TRUE); } -bool partition_info::vers_init_info(THD * thd) -{ - part_type= VERSIONING_PARTITION; - list_of_part_fields= TRUE; - column_list= TRUE; - num_columns= 1; - vers_info= new (thd->mem_root) Vers_part_info; - if (!vers_info) - { - mem_alloc_error(sizeof(Vers_part_info)); - return true; - } - return false; -} - void partition_info::vers_set_hist_part(THD *thd) { if (vers_info->limit) @@ -2747,6 +2732,22 @@ bool check_partition_dirs(partition_info *part_info) #endif /* WITH_PARTITION_STORAGE_ENGINE */ +bool partition_info::vers_init_info(THD * thd) +{ + part_type= VERSIONING_PARTITION; + list_of_part_fields= TRUE; + column_list= TRUE; + num_columns= 1; + vers_info= new (thd->mem_root) Vers_part_info; + if (!vers_info) + { + mem_alloc_error(sizeof(Vers_part_info)); + return true; + } + return false; +} + + bool partition_info::error_if_requires_values() const { switch (part_type) { diff --git a/sql/sql_base.cc b/sql/sql_base.cc index bb61b8a6459..2cfac847b6f 100644 --- a/sql/sql_base.cc +++ b/sql/sql_base.cc @@ -1470,6 +1470,16 @@ open_table_get_mdl_lock(THD *thd, Open_table_context *ot_ctx, return FALSE; } +/* Set all [named] partitions as used. */ +static int set_partitions_as_used(TABLE_LIST *tl, TABLE *t) +{ +#ifdef WITH_PARTITION_STORAGE_ENGINE + if (t->part_info) + return t->file->change_partitions_to_open(tl->partition_names); +#endif + return 0; +} + /** Open a base table. @@ -1612,12 +1622,7 @@ bool open_table(THD *thd, TABLE_LIST *table_list, Open_table_context *ot_ctx) table= best_table; table->query_id= thd->query_id; DBUG_PRINT("info",("Using locked table")); - if (table->part_info) - { - /* Set all [named] partitions as used. */ - part_names_error= - table->file->change_partitions_to_open(table_list->partition_names); - } + part_names_error= set_partitions_as_used(table_list, table); goto reset; } /* @@ -1902,12 +1907,7 @@ retry_share: { DBUG_ASSERT(table->file != NULL); MYSQL_REBIND_TABLE(table->file); - if (table->part_info) - { - /* Set all [named] partitions as used. */ - part_names_error= - table->file->change_partitions_to_open(table_list->partition_names); - } + part_names_error= set_partitions_as_used(table_list, table); } else { @@ -1921,7 +1921,7 @@ retry_share: HA_OPEN_KEYFILE | HA_TRY_READ_ONLY, EXTRA_RECORD, thd->open_options, table, FALSE, - table_list->partition_names); + IF_PARTITIONING(table_list->partition_names,0)); if (error) { diff --git a/sql/sql_table.cc b/sql/sql_table.cc index fae15e11322..0e33a8457b0 100644 --- a/sql/sql_table.cc +++ b/sql/sql_table.cc @@ -9204,8 +9204,8 @@ bool mysql_alter_table(THD *thd, const LEX_CSTRING *new_db, const LEX_CSTRING *n if (table_list->table->versioned(VERS_TRX_ID) && alter_info->requested_algorithm == - Alter_info::ALTER_TABLE_ALGORITHM_DEFAULT && - !table_list->table->s->partition_info_str) + Alter_info::ALTER_TABLE_ALGORITHM_DEFAULT && + IF_PARTITIONING(!table_list->table->s->partition_info_str, 1)) { // Changle default ALGORITHM to COPY for INNODB alter_info->requested_algorithm= Alter_info::ALTER_TABLE_ALGORITHM_COPY; diff --git a/sql/vtmd.cc b/sql/vtmd.cc index 4ee43d61111..b63d7bf3650 100644 --- a/sql/vtmd.cc +++ b/sql/vtmd.cc @@ -35,12 +35,16 @@ VTMD_table::create(THD *thd) return true; Reprepare_observer *reprepare_observer= thd->m_reprepare_observer; - partition_info *work_part_info= thd->work_part_info; thd->m_reprepare_observer= NULL; +#ifdef WITH_PARTITION_STORAGE_ENGINE + partition_info *work_part_info= thd->work_part_info; thd->work_part_info= NULL; +#endif bool rc= mysql_create_like_table(thd, &table, &src_table, &create_info); thd->m_reprepare_observer= reprepare_observer; +#ifdef WITH_PARTITION_STORAGE_ENGINE thd->work_part_info= work_part_info; +#endif return rc; } |