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,14 +5002,17 @@ static my_bool delete_table_force(THD *thd, plugin_ref plugin, void *arg) ...@@ -5001,14 +5002,17 @@ 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;
int error; if (param->discovering == (hton->discover_table != NULL))
error= ha_delete_table(thd, hton, param->path, param->db, param->alias, 0);
if (error > 0 && !non_existing_table_error(error))
param->error= error;
if (error == 0)
{ {
param->error= 0; int error;
return TRUE; // Table was deleted error= ha_delete_table(thd, hton, param->path, param->db, param->alias, 0);
if (error > 0 && !non_existing_table_error(error))
param->error= error;
if (error == 0)
{
param->error= 0;
return TRUE; // Table was deleted
}
} }
return FALSE; return FALSE;
} }
...@@ -5032,15 +5036,23 @@ int ha_delete_table_force(THD *thd, const char *path, const LEX_CSTRING *db, ...@@ -5032,15 +5036,23 @@ int ha_delete_table_force(THD *thd, const char *path, const LEX_CSTRING *db,
Table_exists_error_handler no_such_table_handler; Table_exists_error_handler no_such_table_handler;
DBUG_ENTER("ha_delete_table_force"); DBUG_ENTER("ha_delete_table_force");
param.path= path; param.path= path;
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