Commit b9957ca5 authored by unknown's avatar unknown

BUG#17310: Archive error for drop database


mysql-test/r/partition.result:
  Added new test case
mysql-test/t/partition.test:
  Added new test case
storage/archive/ha_archive.cc:
  Moved some code to avoid that ha_archive::create leaves files after error in create
  There are still cases where this occurs but now only on file creation errors.
parent 597d4cc7
...@@ -936,4 +936,16 @@ OPTIMIZE TABLE t1; ...@@ -936,4 +936,16 @@ OPTIMIZE TABLE t1;
Table Op Msg_type Msg_text Table Op Msg_type Msg_text
test.t1 optimize note The storage engine for the table doesn't support optimize test.t1 optimize note The storage engine for the table doesn't support optimize
drop table t1; drop table t1;
create database db99;
use db99;
create table t1 (a int not null)
engine=archive
partition by list (a)
(partition p0 values in (1), partition p1 values in (2));
insert into t1 values (1), (2);
create index inx on t1 (a);
alter table t1 add partition (partition p2 values in (3));
alter table t1 drop partition p2;
use test;
drop database db99;
End of 5.1 tests End of 5.1 tests
...@@ -1077,4 +1077,21 @@ OPTIMIZE TABLE t1; ...@@ -1077,4 +1077,21 @@ OPTIMIZE TABLE t1;
drop table t1; drop table t1;
#
# Bug 17310 Partitions: Bugs with archived partitioned tables
#
create database db99;
use db99;
create table t1 (a int not null)
engine=archive
partition by list (a)
(partition p0 values in (1), partition p1 values in (2));
insert into t1 values (1), (2);
--error 0, 1005
create index inx on t1 (a);
alter table t1 add partition (partition p2 values in (3));
alter table t1 drop partition p2;
use test;
drop database db99;
--echo End of 5.1 tests --echo End of 5.1 tests
...@@ -701,14 +701,6 @@ int ha_archive::create(const char *name, TABLE *table_arg, ...@@ -701,14 +701,6 @@ int ha_archive::create(const char *name, TABLE *table_arg,
create_info->auto_increment_value -1 : create_info->auto_increment_value -1 :
(ulonglong) 0); (ulonglong) 0);
if ((create_file= my_create(fn_format(name_buff,name,"",ARM,
MY_REPLACE_EXT|MY_UNPACK_FILENAME),0,
O_RDWR | O_TRUNC,MYF(MY_WME))) < 0)
{
error= my_errno;
goto error;
}
for (uint key= 0; key < table_arg->s->keys; key++) for (uint key= 0; key < table_arg->s->keys; key++)
{ {
KEY *pos= table_arg->key_info+key; KEY *pos= table_arg->key_info+key;
...@@ -722,11 +714,20 @@ int ha_archive::create(const char *name, TABLE *table_arg, ...@@ -722,11 +714,20 @@ int ha_archive::create(const char *name, TABLE *table_arg,
if (!(field->flags & AUTO_INCREMENT_FLAG)) if (!(field->flags & AUTO_INCREMENT_FLAG))
{ {
error= -1; error= -1;
DBUG_PRINT("info", ("Index error in creating archive table"));
goto error; goto error;
} }
} }
} }
if ((create_file= my_create(fn_format(name_buff,name,"",ARM,
MY_REPLACE_EXT|MY_UNPACK_FILENAME),0,
O_RDWR | O_TRUNC,MYF(MY_WME))) < 0)
{
error= my_errno;
goto error;
}
write_meta_file(create_file, 0, auto_increment_value, 0, write_meta_file(create_file, 0, auto_increment_value, 0,
(char *)create_info->data_file_name, (char *)create_info->data_file_name,
FALSE); FALSE);
......
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