Commit 2c660584 authored by marko's avatar marko

branches/zip: ha_innobase::add_index(): Do not merely check for a

key name "PRIMARY".  If the table has a generated clustered index,
also check for a UNIQUE INDEX containing no NULL columns.

innobase_create_index_def(): Add the parameter key_primary.

innobase_create_key_def(): Check if the first index is a UNIQUE index
consisting of NOT NULL columns.

Fixing this bug revealed another one: FOREIGN KEY constraints
will be lost when a PRIMARY KEY is created.  This is the reason why
innodb.test will fail.
parent 7279ef6b
...@@ -8067,7 +8067,10 @@ innobase_create_index_def( ...@@ -8067,7 +8067,10 @@ innobase_create_index_def(
/*======================*/ /*======================*/
KEY* key, /* in: key definition */ KEY* key, /* in: key definition */
bool new_primary, /* in: TRUE=generating bool new_primary, /* in: TRUE=generating
a new primary key */ a new primary key
on the table */
bool key_primary, /* in: TRUE if this key
is a primary key */
merge_index_def_t* index, /* out: index definition */ merge_index_def_t* index, /* out: index definition */
mem_heap_t* heap) /* in: heap where memory mem_heap_t* heap) /* in: heap where memory
is allocated */ is allocated */
...@@ -8098,7 +8101,7 @@ innobase_create_index_def( ...@@ -8098,7 +8101,7 @@ innobase_create_index_def(
index->ind_type |= DICT_UNIQUE; index->ind_type |= DICT_UNIQUE;
} }
if (!my_strcasecmp(system_charset_info, key->name, "PRIMARY")) { if (key_primary) {
index->ind_type |= DICT_CLUSTERED; index->ind_type |= DICT_CLUSTERED;
} }
...@@ -8209,17 +8212,36 @@ innobase_create_key_def( ...@@ -8209,17 +8212,36 @@ innobase_create_key_def(
indexdef = indexdefs = (merge_index_def_t*) indexdef = indexdefs = (merge_index_def_t*)
mem_heap_alloc(heap, sizeof *indexdef * n_indexes); mem_heap_alloc(heap, sizeof *indexdef * n_indexes);
/* Primary key if defined is always the first index defined for /* If there is a primary key, it is always the first index
the table */ defined for the table. */
new_primary = !my_strcasecmp(system_charset_info, new_primary = !my_strcasecmp(system_charset_info,
key_info->name, "PRIMARY"); key_info->name, "PRIMARY");
/* If there is a UNIQUE INDEX consisting entirely of NOT NULL
columns, MySQL will treat it as a PRIMARY KEY unless the
table already has one. */
if (!new_primary && (key_info->flags & HA_NOSAME)
&& row_table_got_default_clust_index(table)) {
uint key_part = key_info->key_parts;
new_primary = TRUE;
while (key_part--) {
if (key_info->key_part[key_part].null_bit) {
new_primary = FALSE;
break;
}
}
}
if (new_primary) { if (new_primary) {
const dict_index_t* index; const dict_index_t* index;
/* Create the PRIMARY key index definition */ /* Create the PRIMARY key index definition */
innobase_create_index_def(key_info, TRUE, indexdef++, heap); innobase_create_index_def(key_info, TRUE, TRUE,
indexdef++, heap);
row_mysql_lock_data_dictionary(trx); row_mysql_lock_data_dictionary(trx);
...@@ -8243,7 +8265,7 @@ innobase_create_key_def( ...@@ -8243,7 +8265,7 @@ innobase_create_key_def(
/* Create definitions for added secondary indexes. */ /* Create definitions for added secondary indexes. */
while (i < n_keys) { while (i < n_keys) {
innobase_create_index_def(&key_info[i++], new_primary, innobase_create_index_def(&key_info[i++], new_primary, FALSE,
indexdef++, heap); indexdef++, heap);
} }
......
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