Commit 773ea99f authored by Aditya A's avatar Aditya A

Bug#11751825 - OPTIMIZE PARTITION RECREATES FULL TABLE INSTEAD JUST PARTITION

PROBLEM 
-------

optimize on partiton will recreate the whole table 
instead of just partition.

ANALYSIS
--------

At present innodb doesn't support optimize option ,so we do a rebuild of the 
whole table and then call analyze() on the table.Presently for any optimize()
option (on table or partition) we display the following info to the user 

"Table does not support optimize, doing recreate + analyze instead".

FIX
---

It was decided for GA versions(5.1 and 5.5) whenever the user tries to 
optimize a partition(s) we will will display the following info the user

"Table does not support optimize on partitions.
All partitions will be rebuilt and analyzed."

Earlier partitions were not analyzed.Now all partitions  will be analyzed.  

If the user wants to optimize the whole table ,we will display the
previous info to the user. i.e

"Table does not support optimize, doing recreate + analyze instead"

For 5.6+ versions we will raise a new bug to support optimize() options
in innodb.
parents 296e8573 62ac8fab
...@@ -688,6 +688,11 @@ static bool mysql_admin_table(THD* thd, TABLE_LIST* tables, ...@@ -688,6 +688,11 @@ static bool mysql_admin_table(THD* thd, TABLE_LIST* tables,
case HA_ADMIN_TRY_ALTER: case HA_ADMIN_TRY_ALTER:
{ {
uint save_flags;
Alter_info *alter_info= &lex->alter_info;
/* Store the original value of alter_info->flags */
save_flags= alter_info->flags;
/* /*
This is currently used only by InnoDB. ha_innobase::optimize() answers This is currently used only by InnoDB. ha_innobase::optimize() answers
"try with alter", so here we close the table, do an ALTER TABLE, "try with alter", so here we close the table, do an ALTER TABLE,
...@@ -700,9 +705,18 @@ static bool mysql_admin_table(THD* thd, TABLE_LIST* tables, ...@@ -700,9 +705,18 @@ static bool mysql_admin_table(THD* thd, TABLE_LIST* tables,
thd->mdl_context.release_transactional_locks(); thd->mdl_context.release_transactional_locks();
DEBUG_SYNC(thd, "ha_admin_try_alter"); DEBUG_SYNC(thd, "ha_admin_try_alter");
protocol->store(STRING_WITH_LEN("note"), system_charset_info); protocol->store(STRING_WITH_LEN("note"), system_charset_info);
if(alter_info->flags & ALTER_ADMIN_PARTITION)
{
protocol->store(STRING_WITH_LEN(
"Table does not support optimize on partitions. All partitions "
"will be rebuilt and analyzed."),system_charset_info);
}
else
{
protocol->store(STRING_WITH_LEN( protocol->store(STRING_WITH_LEN(
"Table does not support optimize, doing recreate + analyze instead"), "Table does not support optimize, doing recreate + analyze instead"),
system_charset_info); system_charset_info);
}
if (protocol->write()) if (protocol->write())
goto err; goto err;
DBUG_PRINT("info", ("HA_ADMIN_TRY_ALTER, trying analyze...")); DBUG_PRINT("info", ("HA_ADMIN_TRY_ALTER, trying analyze..."));
...@@ -731,6 +745,11 @@ static bool mysql_admin_table(THD* thd, TABLE_LIST* tables, ...@@ -731,6 +745,11 @@ static bool mysql_admin_table(THD* thd, TABLE_LIST* tables,
table->mdl_request.ticket= NULL; table->mdl_request.ticket= NULL;
DEBUG_SYNC(thd, "ha_admin_open_ltable"); DEBUG_SYNC(thd, "ha_admin_open_ltable");
table->mdl_request.set_type(MDL_SHARED_WRITE); table->mdl_request.set_type(MDL_SHARED_WRITE);
/*
Reset the ALTER_ADMIN_PARTITION bit in alter_info->flags
to force analyze on all partitions.
*/
alter_info->flags &= ~(ALTER_ADMIN_PARTITION);
if ((table->table= open_ltable(thd, table, lock_type, 0))) if ((table->table= open_ltable(thd, table, lock_type, 0)))
{ {
result_code= table->table->file->ha_analyze(thd, check_opt); result_code= table->table->file->ha_analyze(thd, check_opt);
...@@ -741,6 +760,7 @@ static bool mysql_admin_table(THD* thd, TABLE_LIST* tables, ...@@ -741,6 +760,7 @@ static bool mysql_admin_table(THD* thd, TABLE_LIST* tables,
} }
else else
result_code= -1; // open failed result_code= -1; // open failed
alter_info->flags= save_flags;
} }
/* Start a new row for the final status row */ /* Start a new row for the final status row */
protocol->prepare_for_resend(); protocol->prepare_for_resend();
......
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