summaryrefslogtreecommitdiff
path: root/sql/sql_handler.cc
diff options
context:
space:
mode:
authorunknown <serg@serg.mysql.com>2003-01-28 14:36:22 +0100
committerunknown <serg@serg.mysql.com>2003-01-28 14:36:22 +0100
commitd490b56ed1d309cad0ace21a8542983702750f62 (patch)
tree440af93c0ae6daf3a1db266aa402a888dc276e30 /sql/sql_handler.cc
parent3595556335b31d908555da9abaa669d3cfcce1e2 (diff)
downloadmariadb-git-d490b56ed1d309cad0ace21a8542983702750f62.tar.gz
fixed "DROP table_open_in_handler" hang
Diffstat (limited to 'sql/sql_handler.cc')
-rw-r--r--sql/sql_handler.cc37
1 files changed, 22 insertions, 15 deletions
diff --git a/sql/sql_handler.cc b/sql/sql_handler.cc
index 66dcf37d07f..eeaa574c69d 100644
--- a/sql/sql_handler.cc
+++ b/sql/sql_handler.cc
@@ -43,8 +43,8 @@
thd->open_tables=thd->handler_tables; \
thd->handler_tables=tmp; }
-static TABLE **find_table_ptr_by_name(THD *thd, const char *db,
- const char *table_name);
+static TABLE **find_table_ptr_by_name(THD *thd,const char *db,
+ const char *table_name, bool is_alias);
int mysql_ha_open(THD *thd, TABLE_LIST *tables)
{
@@ -68,7 +68,7 @@ int mysql_ha_open(THD *thd, TABLE_LIST *tables)
int mysql_ha_close(THD *thd, TABLE_LIST *tables, bool dont_send_ok)
{
- TABLE **ptr=find_table_ptr_by_name(thd, tables->db, tables->alias);
+ TABLE **ptr=find_table_ptr_by_name(thd, tables->db, tables->alias, 1);
if (*ptr)
{
@@ -87,6 +87,21 @@ int mysql_ha_close(THD *thd, TABLE_LIST *tables, bool dont_send_ok)
return 0;
}
+int mysql_ha_closeall(THD *thd, TABLE_LIST *tables, bool dont_send_ok)
+{
+ TABLE **ptr=find_table_ptr_by_name(thd, tables->db, tables->real_name, 0);
+
+ DBUG_ASSERT(dont_send_ok);
+ if (*ptr)
+ {
+// if (!dont_send_ok) VOID(pthread_mutex_lock(&LOCK_open));
+ close_thread_table(thd, ptr);
+// if (!dont_send_ok) VOID(pthread_mutex_unlock(&LOCK_open));
+ }
+// if (!dont_send_ok) send_ok(&thd->net);
+ return 0;
+}
+
static enum enum_ha_read_modes rkey_to_rnext[]=
{ RNEXT, RNEXT, RPREV, RNEXT, RPREV, RNEXT, RPREV };
@@ -97,7 +112,7 @@ int mysql_ha_read(THD *thd, TABLE_LIST *tables,
ha_rows select_limit,ha_rows offset_limit)
{
int err, keyno=-1;
- TABLE *table=*find_table_ptr_by_name(thd, tables->db, tables->alias);
+ TABLE *table=*find_table_ptr_by_name(thd, tables->db, tables->alias, 1);
if (!table)
{
my_printf_error(ER_UNKNOWN_TABLE,ER(ER_UNKNOWN_TABLE),MYF(0),
@@ -250,17 +265,8 @@ err0:
return -1;
}
-/**************************************************************************
- 2Monty: It could easily happen, that the following service functions are
- already defined somewhere in the code, but I failed to find them.
- If this is the case, just say a word and I'll use old functions here.
-**************************************************************************/
-
-/* Note: this function differs from find_locked_table() because we're looking
- here for alias, not real table name
- */
static TABLE **find_table_ptr_by_name(THD *thd, const char *db,
- const char *alias)
+ const char *table_name, bool is_alias)
{
int dblen;
TABLE **ptr;
@@ -273,9 +279,10 @@ static TABLE **find_table_ptr_by_name(THD *thd, const char *db,
for (TABLE *table=*ptr; table ; table=*ptr)
{
if (!memcmp(table->table_cache_key, db, dblen) &&
- !my_strcasecmp(table->table_name,alias))
+ !my_strcasecmp((is_alias ? table->table_name : table->real_name),table_name))
break;
ptr=&(table->next);
}
return ptr;
}
+