Commit 47859160 authored by Sergei Golubchik's avatar Sergei Golubchik

optimize ha_delete_table_force

first try discovering engines, then the rest.
otherwise every DROP TABLE non_existent; will do
lots of i/o trying to remove .MYI/.MYD/.MAI/.MAD/.CSV/etc files

this matches the old behavior where DROP TABLE always tried to discover
the table before dropping.
parent 4227dd2a
...@@ -4986,6 +4986,7 @@ struct st_force_drop_table_params ...@@ -4986,6 +4986,7 @@ struct st_force_drop_table_params
const LEX_CSTRING *db; const LEX_CSTRING *db;
const LEX_CSTRING *alias; const LEX_CSTRING *alias;
int error; int error;
bool discovering;
}; };
...@@ -5001,6 +5002,8 @@ static my_bool delete_table_force(THD *thd, plugin_ref plugin, void *arg) ...@@ -5001,6 +5002,8 @@ static my_bool delete_table_force(THD *thd, plugin_ref plugin, void *arg)
handlerton *hton = plugin_hton(plugin); handlerton *hton = plugin_hton(plugin);
st_force_drop_table_params *param = (st_force_drop_table_params *)arg; st_force_drop_table_params *param = (st_force_drop_table_params *)arg;
if (param->discovering == (hton->discover_table != NULL))
{
int error; int error;
error= ha_delete_table(thd, hton, param->path, param->db, param->alias, 0); error= ha_delete_table(thd, hton, param->path, param->db, param->alias, 0);
if (error > 0 && !non_existing_table_error(error)) if (error > 0 && !non_existing_table_error(error))
...@@ -5010,6 +5013,7 @@ static my_bool delete_table_force(THD *thd, plugin_ref plugin, void *arg) ...@@ -5010,6 +5013,7 @@ static my_bool delete_table_force(THD *thd, plugin_ref plugin, void *arg)
param->error= 0; param->error= 0;
return TRUE; // Table was deleted return TRUE; // Table was deleted
} }
}
return FALSE; return FALSE;
} }
...@@ -5036,11 +5040,19 @@ int ha_delete_table_force(THD *thd, const char *path, const LEX_CSTRING *db, ...@@ -5036,11 +5040,19 @@ int ha_delete_table_force(THD *thd, const char *path, const LEX_CSTRING *db,
param.db= db; param.db= db;
param.alias= alias; param.alias= alias;
param.error= -1; // Table not found param.error= -1; // Table not found
param.discovering= true;
thd->push_internal_handler(&no_such_table_handler); thd->push_internal_handler(&no_such_table_handler);
if (plugin_foreach(thd, delete_table_force, MYSQL_STORAGE_ENGINE_PLUGIN, if (plugin_foreach(thd, delete_table_force, MYSQL_STORAGE_ENGINE_PLUGIN,
&param)) &param))
param.error= 0; // Delete succeded param.error= 0; // Delete succeded
else
{
param.discovering= false;
if (plugin_foreach(thd, delete_table_force, MYSQL_STORAGE_ENGINE_PLUGIN,
&param))
param.error= 0; // Delete succeded
}
thd->pop_internal_handler(); thd->pop_internal_handler();
DBUG_RETURN(param.error); DBUG_RETURN(param.error);
} }
......
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