mariadb/mysql-test/suite/innodb/t/innodb-index-online-norebuild.test
Thirunarayanan Balathandayuthapani 4b5a9d8e0f Bug #23475211 COMBINING ALTER OPERATIONS TRIGGERS TABLE REBUILD
Problem:
=======
Inplace alter algorithm determines the table to be rebuild if the table
undergoes row format change, key block size if handler flag contains only
change table create option. If alter with inplace ignore flag operations and change table create options then it leads to table rebuild operation.

Solution:
========
During the check for rebuild, ignore the inplace ignore flag and check for
table create options.

Reviewed-by: Jimmy Yang <jimmy.yang@oracle.com>
Reviewed-by: Marko Makela <marko.makela@oracle.com>
RB: 13172
2017-04-24 14:03:22 +03:00

71 lines
1.9 KiB
Text

--source include/have_innodb.inc
--echo # INPLACE ALTER WITH INPLACE_IGNORE FLAG AND CHANGE CREATE OPTION
--echo # CHANGE THE COLUMN DEFAULT (INPLACE_IGNORE)
--echo # AND TABLE CHARSET(CHANGE CREATE)
CREATE TABLE t1(
id INT PRIMARY KEY,
f1 INT NOT NULL DEFAULT 0)ENGINE=INNODB;
INSERT INTO t1 VALUES(1, 2);
let id_before_alter =`SELECT table_id FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES WHERE name="test/t1"`;
# Allow the following operation to report errors.
SET SQL_MODE='STRICT_ALL_TABLES';
ALTER TABLE t1 MODIFY COLUMN f1 INT NOT NULL DEFAULT 0,
DEFAULT CHARSET=latin1, ALGORITHM=INPLACE;
let id_after_alter =`SELECT table_id FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES WHERE name="test/t1"`;
if ($id_before_alter != $id_after_alter)
{
--echo "Table rebuild happened";
}
DROP TABLE t1;
--echo # CHANGE THE COMMENT OF COLUMN(INPLACE IGNORE)
--echo # AND TABLE CHARSET(CHANGE CREATE)
CREATE TABLE t1(id INT COMMENT 'independence day')ENGINE=INNODB;
INSERT INTO t1 values(1);
let id_before_alter =`SELECT table_id FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES WHERE name="test/t1"`;
ALTER TABLE t1 MODIFY COLUMN id INT COMMENT 'identifier',
DEFAULT CHARSET=latin1, ALGORITHM=INPLACE;
let id_after_alter =`SELECT table_id FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES WHERE name="test/t1"`;
if ($id_before_alter != $id_after_alter)
{
--echo "Table rebuild happened";
}
DROP TABLE t1;
--echo # RENAME THE TABLE(INPLACE IGNORE)
--echo # AND CHANGE TABLE CHARSET(CHANGE CREATE)
CREATE TABLE t1(
f1 INT NOT NULL,
f2 INT NOT NULL)ENGINE=INNODB;
INSERT INTO t1 VALUES(1, 2);
let id_before_alter =`SELECT table_id FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES WHERE name="test/t1"`;
ALTER TABLE t1 RENAME t2, DEFAULT CHARSET=latin1, ALGORITHM=INPLACE;
let id_after_alter =`SELECT table_id FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES WHERE name="test/t2"`;
if ($id_before_alter != $id_after_alter)
{
--echo "Table rebuild happened";
}
DROP TABLE t2;