Commit 0829a33c authored by jyang's avatar jyang

branches/zip: Relax assertion on the number of index defined

in InnoDB must be comparable with that of MySQL to tolerate
possible dictionary inconsistency. Fix Mantis issue #455,
"UNIV_DEBUG+ assert ha_innodb.cc:3152 ib_num_index >= 
mysql_num_index".

rb://248 Approved by Marko.
 
parent 9c3431d1
...@@ -3148,11 +3148,17 @@ innobase_build_index_translation( ...@@ -3148,11 +3148,17 @@ innobase_build_index_translation(
mysql_num_index = table->s->keys; mysql_num_index = table->s->keys;
ib_num_index = UT_LIST_GET_LEN(ib_table->indexes); ib_num_index = UT_LIST_GET_LEN(ib_table->indexes);
/* Innodb could have own system indexes. */
ut_a(ib_num_index >= mysql_num_index);
index_mapping = share->idx_trans_tbl.index_mapping; index_mapping = share->idx_trans_tbl.index_mapping;
/* If there exists inconsistency between MySQL and InnoDB dictionary
(metadata) information, the number of index defined in MySQL
could exceed that in InnoDB, do not build index translation
table in such case */
if (UNIV_UNLIKELY(ib_num_index < mysql_num_index)) {
ret = FALSE;
goto func_exit;
}
/* If index entry count is non-zero, nothing has /* If index entry count is non-zero, nothing has
changed since last update, directly return TRUE */ changed since last update, directly return TRUE */
if (share->idx_trans_tbl.index_count) { if (share->idx_trans_tbl.index_count) {
...@@ -5407,11 +5413,18 @@ ha_innobase::innobase_get_index( ...@@ -5407,11 +5413,18 @@ ha_innobase::innobase_get_index(
if (index) { if (index) {
ut_a(ut_strcmp(index->name, key->name) == 0); ut_a(ut_strcmp(index->name, key->name) == 0);
} else { } else {
sql_print_error("InnoDB could not find index %s " /* Can't find index with keynr in the translation
"key no %u for table %s through " table. Only print message if the index translation
" its index translation table", table exists */
key ? key->name : "NULL", keynr, if (share->idx_trans_tbl.index_mapping) {
sql_print_error("InnoDB could not find "
"index %s key no %u for "
"table %s through its "
"index translation table",
key ? key->name : "NULL",
keynr,
prebuilt->table->name); prebuilt->table->name);
}
index = dict_table_get_index_on_name(prebuilt->table, index = dict_table_get_index_on_name(prebuilt->table,
key->name); key->name);
...@@ -7108,10 +7121,13 @@ ha_innobase::records_in_range( ...@@ -7108,10 +7121,13 @@ ha_innobase::records_in_range(
index = innobase_get_index(keynr); index = innobase_get_index(keynr);
ut_a(ut_strcmp(index->name, key->name) == 0); /* There exists possibility of not being able to find requested
index due to inconsistency between MySQL and InoDB dictionary info.
/* MySQL knows about this index and so we must be able to find it.*/ Necessary message should have been printed in innobase_get_index() */
ut_a(index); if (UNIV_UNLIKELY(!index)) {
n_rows = HA_POS_ERROR;
goto func_exit;
}
heap = mem_heap_create(2 * (key->key_parts * sizeof(dfield_t) heap = mem_heap_create(2 * (key->key_parts * sizeof(dfield_t)
+ sizeof(dtuple_t))); + sizeof(dtuple_t)));
...@@ -7156,6 +7172,7 @@ ha_innobase::records_in_range( ...@@ -7156,6 +7172,7 @@ ha_innobase::records_in_range(
mem_heap_free(heap); mem_heap_free(heap);
func_exit:
my_free(key_val_buff2, MYF(0)); my_free(key_val_buff2, MYF(0));
prebuilt->trx->op_info = (char*)""; prebuilt->trx->op_info = (char*)"";
......
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