Commit 5dee7cfc authored by gluh@mysql.com's avatar gluh@mysql.com

Fix for bug #10018:use INFORMATION_SCHEMA works, but show tables in it returns error

parent 82f4a0b0
use INFORMATION_SCHEMA;
show tables;
Tables_in_INFORMATION_SCHEMA
SCHEMATA
TABLES
COLUMNS
CHARACTER_SETS
COLLATIONS
COLLATION_CHARACTER_SET_APPLICABILITY
ROUTINES
STATISTICS
VIEWS
USER_PRIVILEGES
SCHEMA_PRIVILEGES
TABLE_PRIVILEGES
COLUMN_PRIVILEGES
TABLE_CONSTRAINTS
KEY_COLUMN_USAGE
show tables from INFORMATION_SCHEMA like 'T%';
Tables_in_INFORMATION_SCHEMA (T%)
TABLES
TABLE_PRIVILEGES
TABLE_CONSTRAINTS
create database `inf%`;
use `inf%`;
show tables;
Tables_in_inf%
drop database `inf%`;
-- source include/testdb_only.inc
use INFORMATION_SCHEMA;
show tables;
show tables from INFORMATION_SCHEMA like 'T%';
create database `inf%`;
use `inf%`;
show tables;
drop database `inf%`;
...@@ -1777,32 +1777,64 @@ enum enum_schema_tables get_schema_table_idx(ST_SCHEMA_TABLE *schema_table) ...@@ -1777,32 +1777,64 @@ enum enum_schema_tables get_schema_table_idx(ST_SCHEMA_TABLE *schema_table)
/* /*
Add 'information_schema' name to db_names list Create db names list. Information schema name always is first in list
SYNOPSIS SYNOPSIS
schema_db_add() make_db_list()
thd thread handler thd thread handler
files list of db names files list of db names
wild wild string wild wild string
idx_field_vals idx_field_vals->db_name contains db name or
wild string
with_i_schema returns 1 if we added 'IS' name to list with_i_schema returns 1 if we added 'IS' name to list
otherwise returns 0 otherwise returns 0
is_wild_value if value is 1 then idx_field_vals->db_name is
wild string otherwise it's db name;
RETURN RETURN
1 error 1 error
0 success 0 success
*/ */
int schema_db_add(THD *thd, List<char> *files, int make_db_list(THD *thd, List<char> *files,
const char *wild, bool *with_i_schema) INDEX_FIELD_VALUES *idx_field_vals,
bool *with_i_schema, bool is_wild_value)
{ {
LEX *lex= thd->lex;
*with_i_schema= 0; *with_i_schema= 0;
if (!wild || !wild_compare(information_schema_name.str, wild, 0)) get_index_field_values(lex, idx_field_vals);
if (is_wild_value)
{
if (!idx_field_vals->db_value ||
!wild_case_compare(system_charset_info,
information_schema_name.str,
idx_field_vals->db_value))
{ {
*with_i_schema= 1; *with_i_schema= 1;
if (files->push_back(thd->strdup(information_schema_name.str))) if (files->push_back(thd->strdup(information_schema_name.str)))
return 1; return 1;
} }
return 0; return mysql_find_files(thd, files, NullS, mysql_data_home,
idx_field_vals->db_value, 1);
}
if (lex->orig_sql_command != SQLCOM_END)
{
if (!idx_field_vals->db_value ||
!my_strcasecmp(system_charset_info,
information_schema_name.str,
idx_field_vals->db_value))
{
*with_i_schema= 1;
return files->push_back(thd->strdup(information_schema_name.str));
}
return files->push_back(thd->strdup(idx_field_vals->db_value));
}
if (files->push_back(thd->strdup(information_schema_name.str)))
return 1;
*with_i_schema= 1;
return mysql_find_files(thd, files, NullS, mysql_data_home, NullS, 1);
} }
...@@ -1880,14 +1912,9 @@ int get_all_tables(THD *thd, TABLE_LIST *tables, COND *cond) ...@@ -1880,14 +1912,9 @@ int get_all_tables(THD *thd, TABLE_LIST *tables, COND *cond)
if (schema_table_idx == SCH_TABLES) if (schema_table_idx == SCH_TABLES)
lock_type= TL_READ; lock_type= TL_READ;
get_index_field_values(lex, &idx_field_vals);
/* information schema name always is first in list */ if (make_db_list(thd, &bases, &idx_field_vals,
if (schema_db_add(thd, &bases, idx_field_vals.db_value, &with_i_schema)) &with_i_schema, 0))
goto err;
if (mysql_find_files(thd, &bases, NullS, mysql_data_home,
idx_field_vals.db_value, 1))
goto err; goto err;
partial_cond= make_cond_for_info_schema(cond, tables); partial_cond= make_cond_for_info_schema(cond, tables);
...@@ -2022,13 +2049,10 @@ int fill_schema_shemata(THD *thd, TABLE_LIST *tables, COND *cond) ...@@ -2022,13 +2049,10 @@ int fill_schema_shemata(THD *thd, TABLE_LIST *tables, COND *cond)
TABLE *table= tables->table; TABLE *table= tables->table;
DBUG_ENTER("fill_schema_shemata"); DBUG_ENTER("fill_schema_shemata");
get_index_field_values(thd->lex, &idx_field_vals); if (make_db_list(thd, &files, &idx_field_vals,
/* information schema name always is first in list */ &with_i_schema, 1))
if (schema_db_add(thd, &files, idx_field_vals.db_value, &with_i_schema))
DBUG_RETURN(1);
if (mysql_find_files(thd, &files, NullS, mysql_data_home,
idx_field_vals.db_value, 1))
DBUG_RETURN(1); DBUG_RETURN(1);
List_iterator_fast<char> it(files); List_iterator_fast<char> it(files);
while ((file_name=it++)) while ((file_name=it++))
{ {
......
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