mirror of
https://github.com/MariaDB/server.git
synced 2026-05-17 12:27:33 +02:00
MDEV-12586 ALTER TABLE…ALGORITHM=INPLACE fails with non-constant DEFAULT values
ha_innobase::check_if_supported_inplace_alter(): For now, reject ALGORITHM=INPLACE when a non-constant DEFAULT expression is specified for ADD COLUMN or for changing a NULL column to NOT NULL. Later, we should evaluate the non-constant column values in these cases.
This commit is contained in:
parent
85ea327727
commit
0627a0f399
3 changed files with 101 additions and 38 deletions
|
|
@ -2,7 +2,7 @@ CREATE TABLE t1 (
|
|||
`i1` INT(10) UNSIGNED NOT NULL,
|
||||
`d1` TIMESTAMP NULL DEFAULT NULL
|
||||
) ENGINE=innodb;
|
||||
show create table t1;
|
||||
SHOW CREATE TABLE t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`i1` int(10) unsigned NOT NULL,
|
||||
|
|
@ -25,5 +25,26 @@ CREATE TABLE t1 (
|
|||
) ENGINE=innodb;
|
||||
INSERT INTO t1 (i1) VALUES (1), (2), (3), (4), (5);
|
||||
ALTER TABLE t1 CHANGE `d1` `d1` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP;
|
||||
drop table t1;
|
||||
set sql_mode = '';
|
||||
ALTER TABLE t1 ADD COLUMN d2 TIMESTAMP DEFAULT '2017-05-08 16:23:45',
|
||||
LOCK=NONE;
|
||||
ALTER TABLE t1 ADD COLUMN d3 TIMESTAMP DEFAULT d1, LOCK=NONE;
|
||||
ERROR 0A000: LOCK=NONE is not supported for this operation. Try LOCK=SHARED
|
||||
ALTER TABLE t1 ADD COLUMN d3 TIMESTAMP DEFAULT d1, ALGORITHM=INPLACE;
|
||||
ERROR 0A000: ALGORITHM=INPLACE is not supported for this operation. Try ALGORITHM=COPY
|
||||
ALTER TABLE t1 ADD COLUMN d3 TIMESTAMP DEFAULT d1;
|
||||
SELECT d1-d3, d2 FROM t1;
|
||||
d1-d3 d2
|
||||
0 2017-05-08 16:23:45
|
||||
0 2017-05-08 16:23:45
|
||||
0 2017-05-08 16:23:45
|
||||
0 2017-05-08 16:23:45
|
||||
0 2017-05-08 16:23:45
|
||||
SHOW CREATE TABLE t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`i1` int(10) unsigned NOT NULL,
|
||||
`d1` timestamp NOT NULL DEFAULT current_timestamp(),
|
||||
`d2` timestamp NOT NULL DEFAULT '2017-05-08 16:23:45',
|
||||
`d3` timestamp NOT NULL DEFAULT `d1`
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=latin1
|
||||
DROP TABLE t1;
|
||||
|
|
|
|||
|
|
@ -5,7 +5,7 @@ CREATE TABLE t1 (
|
|||
`d1` TIMESTAMP NULL DEFAULT NULL
|
||||
) ENGINE=innodb;
|
||||
|
||||
show create table t1;
|
||||
SHOW CREATE TABLE t1;
|
||||
|
||||
INSERT INTO t1 (i1) VALUES (1), (2), (3), (4), (5);
|
||||
select * from t1;
|
||||
|
|
@ -19,9 +19,14 @@ CREATE TABLE t1 (
|
|||
) ENGINE=innodb;
|
||||
INSERT INTO t1 (i1) VALUES (1), (2), (3), (4), (5);
|
||||
ALTER TABLE t1 CHANGE `d1` `d1` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP;
|
||||
drop table t1;
|
||||
set sql_mode = '';
|
||||
|
||||
|
||||
|
||||
|
||||
ALTER TABLE t1 ADD COLUMN d2 TIMESTAMP DEFAULT '2017-05-08 16:23:45',
|
||||
LOCK=NONE;
|
||||
--error ER_ALTER_OPERATION_NOT_SUPPORTED
|
||||
ALTER TABLE t1 ADD COLUMN d3 TIMESTAMP DEFAULT d1, LOCK=NONE;
|
||||
--error ER_ALTER_OPERATION_NOT_SUPPORTED
|
||||
ALTER TABLE t1 ADD COLUMN d3 TIMESTAMP DEFAULT d1, ALGORITHM=INPLACE;
|
||||
ALTER TABLE t1 ADD COLUMN d3 TIMESTAMP DEFAULT d1;
|
||||
SELECT d1-d3, d2 FROM t1;
|
||||
SHOW CREATE TABLE t1;
|
||||
DROP TABLE t1;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue