mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 00:48:31 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			2778 lines
		
	
	
	
		
			84 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			2778 lines
		
	
	
	
		
			84 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| -- source include/have_partition.inc
 | |
| -- source suite/versioning/common.inc
 | |
| -- source suite/versioning/engines.inc
 | |
| -- source include/have_sequence.inc
 | |
| 
 | |
| set @save_persistent=@@global.innodb_stats_persistent;
 | |
| set global innodb_stats_persistent= 0;
 | |
| 
 | |
| call mtr.add_suppression("need more HISTORY partitions");
 | |
| 
 | |
| --enable_prepare_warnings
 | |
| 
 | |
| set system_versioning_alter_history=keep;
 | |
| --let $datadir= `select @@datadir`
 | |
| --echo # Check conventional partitioning on temporal tables
 | |
| 
 | |
| --replace_result $sys_datatype_expl SYS_DATATYPE
 | |
| eval create or replace table t1 (
 | |
|     x int,
 | |
|     row_start $sys_datatype_expl as row start invisible,
 | |
|     row_end $sys_datatype_expl as row end invisible,
 | |
|     period for system_time(row_start, row_end))
 | |
| with system versioning
 | |
| partition by range columns (x) (
 | |
|     partition p0 values less than (100),
 | |
|     partition p1 values less than (1000));
 | |
| 
 | |
| insert into t1 values (3), (300);
 | |
| select * from t1;
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| 
 | |
| delete from t1;
 | |
| select * from t1;
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 for system_time all;
 | |
| select * from t1 partition (p0) for system_time all;
 | |
| select * from t1 partition (p1) for system_time all;
 | |
| 
 | |
| --echo # Engine change native <-> non-native versioning prohibited
 | |
| --replace_result $sys_datatype_expl SYS_DATATYPE $default_engine DEFAULT_ENGINE
 | |
| eval create or replace table t1 (
 | |
|     i int,
 | |
|     row_start $sys_datatype_expl as row start invisible,
 | |
|     row_end $sys_datatype_expl as row end invisible,
 | |
|     period for system_time(row_start, row_end))
 | |
| engine=$default_engine
 | |
| with system versioning partition by hash(i);
 | |
| --replace_result $non_default_engine NON_DEFAULT_ENGINE
 | |
| --error ER_VERS_ALTER_ENGINE_PROHIBITED
 | |
| eval alter table t1 engine=$non_default_engine;
 | |
| 
 | |
| 
 | |
| --echo ## CREATE TABLE
 | |
| 
 | |
| --error ER_VERS_NOT_VERSIONED
 | |
| create or replace table t1 (x int)
 | |
| partition by system_time (
 | |
|     partition p0 history,
 | |
|     partition pn current);
 | |
| 
 | |
| create or replace table t1 (x int);
 | |
| --error ER_VERS_NOT_VERSIONED
 | |
| alter table t1
 | |
| partition by system_time (
 | |
|     partition p0 history,
 | |
|     partition pn current);
 | |
| 
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time (
 | |
|     partition p0 current);
 | |
| 
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time (
 | |
|     partition p0 current,
 | |
|     partition p1 current);
 | |
| 
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time (
 | |
|     partition p0 history,
 | |
|     partition p1 history);
 | |
| 
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time (
 | |
|     partition pn current,
 | |
|     partition p0 history);
 | |
| 
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time (
 | |
|     partition p0,
 | |
|     partition pn current);
 | |
| 
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time (
 | |
|     partition p0 history,
 | |
|     partition pn current);
 | |
| 
 | |
| --error ER_PARTITION_WRONG_TYPE
 | |
| create or replace table t1 (a int)
 | |
| partition by range (a) (
 | |
|   partition p0 history,
 | |
|   partition p1 current);
 | |
| 
 | |
| --error ER_PARTITION_WRONG_TYPE
 | |
| create or replace table t1 (b int)
 | |
| partition by range (a) (
 | |
|   partition p0 current,
 | |
|   partition p1 history);
 | |
| 
 | |
| 
 | |
| --echo ## ALTER TABLE
 | |
| 
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| alter table t1 add partition (
 | |
|     partition p1 current);
 | |
| 
 | |
| alter table t1 add partition (
 | |
|     partition p1 history);
 | |
| 
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| insert into t1 values (1), (2);
 | |
| 
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| alter table t1 drop partition pn;
 | |
| alter table t1 drop partition p1;
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| alter table t1 drop partition p0;
 | |
| 
 | |
| select x from t1;
 | |
| 
 | |
| --echo # rename works
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time;
 | |
| alter table t1 reorganize partition p0 into
 | |
| (partition custom_name history);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| --echo # merge and split doesn't (MDEV-19938)
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time limit 10 partitions 3;
 | |
| --error ER_REORG_HASH_ONLY_ON_SAME_NO
 | |
| alter table t1 reorganize partition p0, p1 into (partition p00 history);
 | |
| --error ER_REORG_HASH_ONLY_ON_SAME_NO
 | |
| alter table t1 reorganize partition p1 into (partition p1 history, partition p2 history);
 | |
| 
 | |
| 
 | |
| --echo # Bug tempesta-tech/mariadb#260: incorrect IB partitioning warning
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time limit 1;
 | |
| alter table t1 change x big int;
 | |
| 
 | |
| create or replace table t1 (i int) engine myisam partition by hash(i) partitions 2;
 | |
| --error ER_PARTITION_WRONG_TYPE
 | |
| alter table t1 add partition (partition px history);
 | |
| 
 | |
| 
 | |
| --echo ## INSERT, UPDATE, DELETE
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time;
 | |
| 
 | |
| set @now= now(6);
 | |
| insert into t1 values (1);
 | |
| set @str= concat('select x, row_start < @now as A, row_end > @now as B from t1 partition (p0)');
 | |
| prepare select_p0 from @str;
 | |
| --replace_result $sys_time_max SYS_TIME_MAX
 | |
| --eval set @str= concat("select x, row_start > @now as C, row_end = $sys_time_max as D from t1 partition (pn)");
 | |
| prepare select_pn from @str;
 | |
| 
 | |
| execute select_p0;
 | |
| execute select_pn;
 | |
| 
 | |
| set @str= concat('select row_start from t1 partition (pn) into @ts0');
 | |
| prepare stmt from @str; execute stmt; drop prepare stmt;
 | |
| 
 | |
| --source suite/versioning/wait_system_clock.inc
 | |
| 
 | |
| set @now= now(6);
 | |
| delete from t1;
 | |
| execute select_p0;
 | |
| execute select_pn;
 | |
| 
 | |
| set @str= concat('select row_start from t1 partition (p0) into @ts1');
 | |
| prepare stmt from @str; execute stmt; drop prepare stmt;
 | |
| 
 | |
| select @ts0 = @ts1;
 | |
| 
 | |
| set @now= now(6);
 | |
| insert into t1 values (2);
 | |
| 
 | |
| --source suite/versioning/wait_system_clock.inc
 | |
| 
 | |
| execute select_p0;
 | |
| execute select_pn;
 | |
| 
 | |
| set @str= concat('select row_start from t1 partition (pn) into @ts0');
 | |
| prepare stmt from @str; execute stmt; drop prepare stmt;
 | |
| 
 | |
| set @now= now(6);
 | |
| update t1 set x = x + 1;
 | |
| 
 | |
| --source suite/versioning/wait_system_clock.inc
 | |
| 
 | |
| execute select_p0;
 | |
| execute select_pn;
 | |
| 
 | |
| drop prepare select_p0;
 | |
| drop prepare select_pn;
 | |
| 
 | |
| set @str= concat('select row_start from t1 partition (p0) where x = 2 into @ts1');
 | |
| prepare stmt from @str; execute stmt; drop prepare stmt;
 | |
| set @str= concat('select row_end from t1 partition (p0) where x = 2 into @ts2');
 | |
| prepare stmt from @str; execute stmt; drop prepare stmt;
 | |
| set @str= concat('select row_start from t1 partition (pn) into @ts3');
 | |
| prepare stmt from @str; execute stmt; drop prepare stmt;
 | |
| 
 | |
| select @ts0 = @ts1;
 | |
| select @ts2 = @ts3;
 | |
| 
 | |
| --echo #
 | |
| --echo # Rotation by LIMIT
 | |
| --echo #
 | |
| --error ER_PART_WRONG_VALUE
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time limit 0 partitions 3;
 | |
| 
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time limit 2 partitions 3;
 | |
| 
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| --error ER_PARTITION_DOES_NOT_EXIST
 | |
| alter table t1 drop partition non_existent;
 | |
| 
 | |
| insert into t1 values (1), (2), (3), (4), (5), (6);
 | |
| select * from t1 partition (pn);
 | |
| delete from t1 where x < 4;
 | |
| delete from t1;
 | |
| --echo # You see warning above ^
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| 
 | |
| insert into t1 values (7), (8);
 | |
| --echo ### warn about full partition
 | |
| delete from t1;
 | |
| --echo # You see warning above ^
 | |
| select * from t1 partition (p1) order by x;
 | |
| 
 | |
| --echo #
 | |
| --echo # Rotation by INTERVAL
 | |
| --echo #
 | |
| --error ER_PART_WRONG_VALUE
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time interval 0 second partitions 3;
 | |
| 
 | |
| --error ER_PARSE_ERROR
 | |
| create table t1 (i int) with system versioning
 | |
| partition by system_time interval 6 day limit 98;
 | |
| 
 | |
| --error ER_DATA_OUT_OF_RANGE
 | |
| create or replace table t1 (pk int) with system versioning
 | |
| partition by system_time interval 60 year partitions 3;
 | |
| 
 | |
| --echo # INTERVAL and ALTER TABLE
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 hour;
 | |
| 
 | |
| set @ts=(select partition_description from information_schema.partitions
 | |
|   where table_schema='test' and table_name='t1' and partition_name='p0');
 | |
| 
 | |
| alter table t1 add column b int;
 | |
| select partition_name,partition_ordinal_position,partition_method,timediff(partition_description, @ts) from information_schema.partitions where table_schema='test' and table_name='t1';
 | |
| alter table t1 add partition (partition p1 history, partition p2 history);
 | |
| select partition_name,partition_ordinal_position,partition_method,timediff(partition_description, @ts) from information_schema.partitions where table_schema='test' and table_name='t1';
 | |
| alter table t1 drop partition p0;
 | |
| select partition_name,partition_ordinal_position,partition_method,timediff(partition_description, @ts) from information_schema.partitions where table_schema='test' and table_name='t1';
 | |
| --error ER_VERS_DROP_PARTITION_INTERVAL
 | |
| alter table t1 drop partition p2;
 | |
| select partition_name,partition_ordinal_position,partition_method,timediff(partition_description, @ts) from information_schema.partitions where table_schema='test' and table_name='t1';
 | |
| 
 | |
| #
 | |
| # partition rotation (moved from partition_rotation.test)
 | |
| #
 | |
| set timestamp=unix_timestamp('2001-02-03 10:20:30');
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day
 | |
|     subpartition by key (i) subpartitions 2
 | |
|     (partition p1 history, partition pn current);
 | |
| set timestamp=unix_timestamp('2001-02-03 10:20:40');
 | |
| insert t1 values (1); delete from t1;
 | |
| set timestamp=unix_timestamp('2001-02-04 10:20:50');
 | |
| insert t1 values (2); delete from t1;
 | |
| 
 | |
| select subpartition_name, partition_description, table_rows from information_schema.partitions where table_schema='test' and table_name='t1';
 | |
| select * from t1 partition (p1);
 | |
| 
 | |
| set timestamp=unix_timestamp('2001-02-04 10:20:55');
 | |
| alter table t1 add partition (partition p0 history, partition p2 history);
 | |
| set timestamp=unix_timestamp('2001-02-04 10:30:00');
 | |
| insert t1 values (4),(5);
 | |
| set timestamp=unix_timestamp('2001-02-04 10:30:10');
 | |
| update t1 set i=6 where i=5;
 | |
| 
 | |
| select subpartition_name, partition_description, table_rows from information_schema.partitions where table_schema='test' and table_name='t1';
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p2);
 | |
| 
 | |
| alter table t1 rebuild partition p0, p1, p2;
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p2);
 | |
| 
 | |
| --echo ## pruning check
 | |
| set @ts=(select partition_description from information_schema.partitions
 | |
|   where table_schema='test' and table_name='t1' and partition_name='p0' limit 1);
 | |
| --sorted_result
 | |
| select * from t1;
 | |
| --replace_column 10 #
 | |
| explain partitions select * from t1;
 | |
| --replace_column 10 #
 | |
| explain partitions select * from t1 for system_time as of '2001-02-04 10:20:30';
 | |
| set @ts=(select row_end from t1 for system_time all where i=1);
 | |
| select * from t1 for system_time all where row_end = @ts;
 | |
| --replace_column 5 # 10 # 11 #
 | |
| explain partitions select * from t1 for system_time all where row_end = @ts;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-16023 Unfortunate error message WARN_VERS_PART_FULL
 | |
| --echo #
 | |
| 
 | |
| set timestamp= unix_timestamp('2020-07-29 10:30:10');
 | |
| create or replace table t1 (a int) with system versioning
 | |
|   partition by system_time interval 1 second (
 | |
|     partition p0 history,
 | |
|     partition p1 history,
 | |
|     partition pc current
 | |
|   );
 | |
| 
 | |
| set timestamp= unix_timestamp('2020-07-29 10:30:14');
 | |
| insert into t1 values (1),(2),(3);
 | |
| show warnings;
 | |
| 
 | |
| --echo # Cleanup
 | |
| set timestamp= default;
 | |
| 
 | |
| --echo ## INTERVAL ... STARTS
 | |
| --error ER_PART_WRONG_VALUE
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts 'a';
 | |
| 
 | |
| --error ER_PART_WRONG_VALUE
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts '00:00:00';
 | |
| 
 | |
| --error ER_PART_WRONG_VALUE
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts '2000-00-01 00:00:00';
 | |
| 
 | |
| --error ER_PART_WRONG_VALUE
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts 946684800;
 | |
| 
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts '2000-01-01 00:00:00';
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| --echo # Test STARTS warning
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts '2000-01-01 00:00:01';
 | |
| 
 | |
| --echo # Test default STARTS rounding
 | |
| set timestamp= unix_timestamp('1999-12-15 13:33:33');
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 second;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 minute;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 hour;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 month;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 year;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| --echo # seconds equivalent of 1 day does not round:
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 86400 second;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| --echo # STARTS value is in local time_zone:
 | |
| set time_zone="+03:00";
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts '2000-01-01 00:00:00';
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t2 (i int) with system versioning
 | |
| partition by system_time interval 1 day;
 | |
| 
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t2;
 | |
| set time_zone="+00:00";
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t2;
 | |
| 
 | |
| --echo # Test rotation
 | |
| set timestamp= unix_timestamp('2001-01-01 00:00:00');
 | |
| --echo # it's ok to add partitions for past:
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts '2000-01-01 00:00:00'
 | |
| partitions 3;
 | |
| 
 | |
| insert into t1 values (0);
 | |
| set timestamp= unix_timestamp('2001-01-01 00:00:01');
 | |
| update t1 set i= i + 1;
 | |
| set timestamp= unix_timestamp('2001-01-01 00:00:02');
 | |
| update t1 set i= i + 1;
 | |
| 
 | |
| select *, row_end from t1 partition (p0);
 | |
| select *, row_end from t1 partition (p1);
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| --echo # now we "overflow" first partition a bit:
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts '2000-01-03 00:00:00'
 | |
| partitions 3;
 | |
| 
 | |
| insert into t1 values (0);
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:01');
 | |
| update t1 set i= i + 1;
 | |
| set timestamp= unix_timestamp('2000-01-02 00:00:01');
 | |
| update t1 set i= i + 1;
 | |
| set timestamp= unix_timestamp('2000-01-03 00:00:01');
 | |
| update t1 set i= i + 1;
 | |
| set timestamp= unix_timestamp('2000-01-04 00:00:01');
 | |
| update t1 set i= i + 1;
 | |
| 
 | |
| select *, row_end from t1 partition (p0);
 | |
| select *, row_end from t1 partition (p1);
 | |
| 
 | |
| --echo # and this is how it usually goes:
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day
 | |
| partitions 3;
 | |
| 
 | |
| insert into t1 values (0);
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:01');
 | |
| update t1 set i= i + 1;
 | |
| set timestamp= unix_timestamp('2000-01-02 00:00:01');
 | |
| update t1 set i= i + 1;
 | |
| set timestamp= unix_timestamp('2000-01-03 00:00:01');
 | |
| update t1 set i= i + 1;
 | |
| set timestamp= unix_timestamp('2000-01-04 00:00:01');
 | |
| update t1 set i= i + 1;
 | |
| 
 | |
| alter table t1 add partition (partition p2 history, partition p3 history);
 | |
| select *, row_end from t1 partition (p0);
 | |
| select *, row_end from t1 partition (p1);
 | |
| select *, row_end from t1 partition (p2);
 | |
| select *, row_end from t1 partition (p3);
 | |
| 
 | |
| drop tables t1, t2;
 | |
| 
 | |
| --echo ## Subpartitions
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by system_time limit 2 partitions 3
 | |
| subpartition by key (x)
 | |
| subpartitions 2;
 | |
| 
 | |
| insert into t1 (x) values (1), (2), (3), (4), (5);
 | |
| select * from t1 partition (pnsp0);
 | |
| select * from t1 partition (pnsp1);
 | |
| 
 | |
| delete from t1 where x < 3;
 | |
| delete from t1;
 | |
| --echo # You see warning above ^
 | |
| delete from t1;
 | |
| --echo # You see warning above ^ (no matter if nothing was deleted)
 | |
| select * from t1 partition (p0sp0);
 | |
| select * from t1 partition (p0sp1);
 | |
| select * from t1 partition (p1sp0);
 | |
| select * from t1 partition (p1sp1);
 | |
| 
 | |
| --echo # check implicit sys fields for implicit engine of partitioned table
 | |
| create or replace table t1 (a bigint)
 | |
| with system versioning
 | |
| partition by range (a)
 | |
| (partition p0 values less than (20) engine innodb,
 | |
|  partition p1 values less than maxvalue engine innodb);
 | |
| insert into t1 values (1);
 | |
| select * from t1 partition (p0);
 | |
| 
 | |
| --echo # check for partition engine
 | |
| create or replace table t1 (
 | |
|   f_int1 integer default 0
 | |
| ) with system versioning
 | |
| partition by range(f_int1)
 | |
| subpartition by hash(f_int1)
 | |
| ( partition part1 values less than (1000)
 | |
| (subpartition subpart11 storage engine = 'innodb',
 | |
| subpartition subpart12 storage engine = 'innodb'));
 | |
| insert into t1 values (1);
 | |
| select * from t1 partition (part1);
 | |
| 
 | |
| --echo #
 | |
| --echo # TRX_ID versioning (moved from partition_innodb.test)
 | |
| --echo #
 | |
| --echo # MDEV-15951 system versioning by trx id doesn't work with partitioning
 | |
| --echo # currently trx_id does not support partitioning by system_time
 | |
| --error ER_VERS_FIELD_WRONG_TYPE
 | |
| create or replace table t1(
 | |
|   i int,
 | |
|   row_start bigint unsigned generated always as row start,
 | |
|   row_end bigint unsigned generated always as row end,
 | |
|   period for system_time(row_start, row_end)
 | |
| ) engine=InnoDB with system versioning partition by system_time (
 | |
|   partition p0 history,
 | |
|   partition pn current
 | |
| );
 | |
| 
 | |
| create or replace table t1(
 | |
|   i int,
 | |
|   row_start bigint unsigned generated always as row start,
 | |
|   row_end bigint unsigned generated always as row end,
 | |
|   period for system_time(row_start, row_end)
 | |
| ) engine=InnoDB with system versioning;
 | |
| 
 | |
| --error ER_VERS_FIELD_WRONG_TYPE
 | |
| alter table t1  partition by system_time (
 | |
|   partition p0 history,
 | |
|   partition pn current
 | |
| );
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| --error ER_VERS_TRX_PART_HISTORIC_ROW_NOT_SUPPORTED
 | |
| create or replace table t (
 | |
|   a int primary key,
 | |
|   row_start bigint unsigned as row start invisible,
 | |
|   row_end bigint unsigned as row end invisible,
 | |
|   period for system_time(row_start, row_end)
 | |
| ) engine=innodb with system versioning
 | |
| partition by key() (
 | |
|   partition p1,
 | |
|   partition p2
 | |
| );
 | |
| 
 | |
| --error ER_VERS_TRX_PART_HISTORIC_ROW_NOT_SUPPORTED
 | |
| create or replace table t (
 | |
|   a int primary key,
 | |
|   row_start bigint unsigned as row start invisible,
 | |
|   row_end bigint unsigned as row end invisible,
 | |
|   period for system_time(row_start, row_end)
 | |
| ) engine=innodb with system versioning
 | |
| partition by key(a, row_start) (
 | |
|   partition p1,
 | |
|   partition p2
 | |
| );
 | |
| 
 | |
| --error ER_VERS_TRX_PART_HISTORIC_ROW_NOT_SUPPORTED
 | |
| create or replace table t (
 | |
|   a int primary key,
 | |
|   row_start bigint unsigned as row start invisible,
 | |
|   row_end bigint unsigned as row end invisible,
 | |
|   period for system_time(row_start, row_end)
 | |
| ) engine=innodb with system versioning
 | |
| partition by hash(a + row_end * 2) (
 | |
|   partition p1,
 | |
|   partition p2
 | |
| );
 | |
| 
 | |
| --error ER_VERS_TRX_PART_HISTORIC_ROW_NOT_SUPPORTED
 | |
| create or replace table t (
 | |
|   a int primary key,
 | |
|   row_start bigint unsigned as row start invisible,
 | |
|   row_end bigint unsigned as row end invisible,
 | |
|   period for system_time(row_start, row_end)
 | |
| ) engine=innodb with system versioning
 | |
| partition by range columns (a, row_start) (
 | |
|   partition p1 values less than (100, 100)
 | |
| );
 | |
| 
 | |
| --echo #
 | |
| --echo # Assertion in ALTER on warning from partitioning LIMIT [#446]
 | |
| --echo #
 | |
| create or replace table t1 (x int) with system versioning;
 | |
| insert into t1 values (1), (2);
 | |
| delete from t1;
 | |
| alter table t1 partition by system_time limit 1 (
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-14649 Assertion `t->mysql_col_len == 8' failed in row_insert_for_mysql
 | |
| --echo #
 | |
| create or replace table t1 (i int) engine=innodb partition by key(i);
 | |
| alter table t1 add system versioning;
 | |
| insert into t1 values();
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-14722 Assertion in ha_commit_trans for sub-statement
 | |
| --echo #
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day;
 | |
| create or replace table t2 (f int);
 | |
| create or replace trigger tr before insert on t2
 | |
| for each row select table_rows from information_schema.tables
 | |
| where table_name = 't1' into @a;
 | |
| insert into t2 values (1);
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-14740 Locking assertion for system_time partitioning
 | |
| --echo #
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 week;
 | |
| create or replace table t2 (f int);
 | |
| create or replace trigger tr before insert on t2
 | |
| for each row select count(*) from t1 into @a;
 | |
| insert into t2 values (1);
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-14747 ALTER PARTITION BY SYSTEM_TIME after LOCK TABLES
 | |
| --echo #
 | |
| create or replace table t1 (x int) with system versioning;
 | |
| lock table t1 write;
 | |
| alter table t1 partition by system_time interval 1 week (
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| unlock tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-14748 Assertion in ha_myisammrg::attach_children()
 | |
| --echo #
 | |
| create or replace table t1 (x int) engine=myisam with system versioning
 | |
|   partition by system_time interval 1 month (partition p1 history, partition pn current);
 | |
| create or replace table t2 (x int) engine=myisam;
 | |
| create or replace table t3 (x int) engine=merge union=(t2);
 | |
| create or replace table t4 (x int) engine=myisam;
 | |
| create or replace trigger tr after insert on t4 for each row insert into t2
 | |
|   ( select x from t3 ) union ( select x from t1 );
 | |
| insert into t4 values (1);
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-14821 Assertion failure
 | |
| --echo #
 | |
| create or replace table t1 (x int) with system versioning;
 | |
| insert into t1 values (0), (1);
 | |
| update t1 set x= x + 1;
 | |
| alter table t1 partition by system_time limit 1 (
 | |
|     partition p1 history,
 | |
|     partition p2 history,
 | |
|     partition pn current);
 | |
| delete from t1 where x = 1;
 | |
| --echo # You see warning above ^
 | |
| delete from t1 where x = 2;
 | |
| --echo # You see warning above ^
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-14923 Assertion upon INSERT into locked versioned partitioned table
 | |
| --echo #
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time;
 | |
| lock table t1 write;
 | |
| --error ER_SAME_NAME_PARTITION
 | |
| alter table t1 add partition (partition p0 history);
 | |
| insert into t1 values (1);
 | |
| unlock tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-15103 Assertion in ha_partition::part_records() for updating VIEW
 | |
| --echo #
 | |
| create or replace table t1 (pk int primary key, f int) with system versioning
 | |
| partition by system_time limit 100;
 | |
| insert into t1 values (1,10), (2,20);
 | |
| create or replace view v1 as select * from t1;
 | |
| update v1 set f= 30;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-15168 Unexpected ER_VERS_ENGINE_UNSUPPORTED upon dropping versioning on a partitioned table
 | |
| --echo #
 | |
| create or replace table t (a int) with system versioning
 | |
| partition by system_time;
 | |
| --error ER_DROP_VERSIONING_SYSTEM_TIME_PARTITION
 | |
| alter table t drop system versioning;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-15191 Assertion `bit < (map)->n_bits' failed in bitmap_is_set upon INSERT
 | |
| --echo #
 | |
| create or replace table t1 (i int) with system versioning;
 | |
| insert into t1 values (1), (2);
 | |
| update t1 set i= 3;
 | |
| alter table t1 partition by system_time interval 1 month (partition p1 history, partition pn current);
 | |
| lock table t1 write;
 | |
| alter table t1 add partition (partition p2 history);
 | |
| insert into t1 values (4);
 | |
| unlock tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-15036 Assertion `!is_set() || (m_status == DA_OK_BULK && is_bulk_op())' in Diagnostics_area::set_ok_status or unexpected ER_RANGE_NOT_INCREASING_ERROR
 | |
| --echo #
 | |
| create or replace table t1 (a int) with system versioning
 | |
| partition by system_time limit 2 partitions 4;
 | |
| insert into t1 values (1),(2),(3);
 | |
| update t1 set a = 4;
 | |
| delete from t1;
 | |
| delete from t1 where a is not null;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-14823 Wrong error message upon selecting from a system_time partition
 | |
| --echo #
 | |
| create or replace table t1 (i int) with system versioning partition by system_time limit 10;
 | |
| --error ER_VERS_QUERY_IN_PARTITION
 | |
| select * from t1 partition (p0) for system_time all;
 | |
| --echo # MDEV-18929 2nd execution of SP does not detect ER_VERS_NOT_VERSIONED
 | |
| create or replace procedure sp()
 | |
| select * from t1 partition (p0) for system_time all;
 | |
| --error ER_VERS_QUERY_IN_PARTITION
 | |
| call sp;
 | |
| --error ER_VERS_QUERY_IN_PARTITION
 | |
| call sp;
 | |
| drop procedure sp;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-15380 Index for versioned table gets corrupt after partitioning and DELETE
 | |
| --echo #
 | |
| create or replace table t1 (pk int primary key)
 | |
|   engine=myisam
 | |
|   with system versioning
 | |
|   partition by key() partitions 3;
 | |
| set timestamp=1523466002.799571;
 | |
| insert into t1 values (11),(12);
 | |
| set timestamp=1523466004.169435;
 | |
| delete from t1 where pk in (11, 12);
 | |
| --echo Same test but for Aria storage engine
 | |
| create or replace table t1 (pk int primary key)
 | |
|   engine=aria
 | |
|   with system versioning
 | |
|   partition by key() partitions 3;
 | |
| set timestamp=1523466002.799571;
 | |
| insert into t1 values (11),(12);
 | |
| set timestamp=1523466004.169435;
 | |
| delete from t1 where pk in (11, 12);
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-18136 Server crashes in Item_func_dyncol_create::prepare_arguments
 | |
| --echo #
 | |
| create or replace table t1 (pk int) with system versioning
 | |
| partition by system_time interval 7 second;
 | |
| alter table t1
 | |
| partition by system_time interval column_get(column_create(7,7), 7 as int) second (
 | |
|   partition ver_p1 history,
 | |
|   partition ver_pn current);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| set timestamp= default;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-18794 Assertion `!m_innodb' failed in ha_partition::cmp_ref upon SELECT from partitioned table
 | |
| --echo #
 | |
| create or replace table t1 (pk int auto_increment, i int, c char(1), primary key (pk), key(i))
 | |
| engine=innodb with system versioning partition by key() partitions 2;
 | |
| insert into t1 (i, c) values (1, 'a'), (2, 'b'), (null, 'c'), (null, 'b');
 | |
| alter table t1 drop system versioning;
 | |
| replace into t1 select * from t1;
 | |
| select * from t1 where i > 0 or pk = 1000 limit 1;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-19175 Server crashes in ha_partition::vers_can_native upon INSERT DELAYED into versioned partitioned table
 | |
| --echo #
 | |
| create or replace table t1 (f int) with system versioning partition by hash(f);
 | |
| # delayed works differently in embedded server
 | |
| --error 0,ER_DELAYED_NOT_SUPPORTED
 | |
| insert delayed into t1 values (1);
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-20068 History partition rotation is not done under LOCK TABLES
 | |
| --echo #
 | |
| create or replace table t1 (x int) with system versioning partition by system_time limit 1
 | |
| (partition p1 history, partition pn current);
 | |
| lock tables t1 write;
 | |
| insert into t1 values (0), (1), (2), (3);
 | |
| delete from t1 where x < 3;
 | |
| --echo # You see warning above ^
 | |
| delete from t1;
 | |
| --echo # You see warning above ^
 | |
| unlock tables;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-20336 Assertion bitmap_is_set(read_partitions) upon SELECT FOR UPDATE from versioned table
 | |
| --echo #
 | |
| create or replace table t1 (pk int primary key) with system versioning partition by system_time limit 100 (partition p1 history, partition pn current);
 | |
| execute immediate 'select * from t1 for update';
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-19903 Setup default partitions for system versioning
 | |
| --echo #
 | |
| create or replace table t1 (x int) with system versioning partition by system_time;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --echo # 2 partitions are created: p0 and pn
 | |
| select PARTITION_NAME, PARTITION_METHOD, PARTITION_DESCRIPTION from information_schema.partitions where table_name = 't1' order by PARTITION_NAME;
 | |
| 
 | |
| create or replace table t1 (x int) with system versioning partition by system_time limit 10 partitions 4;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --echo # 4 partitions are created: p0, p1, p2 and pn
 | |
| select PARTITION_NAME, PARTITION_METHOD, PARTITION_DESCRIPTION from information_schema.partitions where table_name = 't1' order by PARTITION_NAME;
 | |
| 
 | |
| --echo # Test cleanup
 | |
| drop view v1;
 | |
| drop tables t, t1, t2, t3, t4;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-18957 UPDATE with LIMIT clause is wrong for versioned partitioned tables
 | |
| --echo #
 | |
| create or replace table t1 (
 | |
|   x int,
 | |
|   a varchar(255)
 | |
| ) with system versioning partition by system_time (partition p1 history, partition pn current);
 | |
| 
 | |
| insert into t1 (x) values (1), (2), (3), (4);
 | |
| update t1 set a= 'foo' limit 3;
 | |
| update t1 set a= 'bar' limit 4;
 | |
| select * from t1;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-21011 Table corruption reported for versioned partitioned table after DELETE: "Found a misplaced row"
 | |
| --echo #
 | |
| create table t1 (a int) with system versioning
 | |
| partition by system_time limit 3
 | |
| (partition p1 history, partition p2 history, partition pn current);
 | |
| insert into t1 values (1),(2),(3),(4);
 | |
| delete from t1;
 | |
| delete from t1;
 | |
| check table t1;
 | |
| 
 | |
| # cleanup
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-21233 Assertion `m_extra_cache' failed in ha_partition::late_extra_cache
 | |
| --echo #
 | |
| create table t1 (id int, a varchar(8)) with system versioning partition by key (id) partitions 2;
 | |
| insert into t1 values  (1,'foo'),(2,'bar');
 | |
| 
 | |
| create table t2 (b int);
 | |
| insert into t2 values (1),(2);
 | |
| 
 | |
| update t1, t2 set a = 1;
 | |
| 
 | |
| # cleanup
 | |
| drop table t1, t2;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-20515 multi-update tries to position updated table by null reference
 | |
| --echo #
 | |
| create or replace table t1 (a int);
 | |
| insert into t1 values (0), (1);
 | |
| 
 | |
| create or replace table t2 (b int) with system versioning
 | |
| partition by system_time
 | |
| (partition p1 history, partition pn current);
 | |
| 
 | |
| insert into t2 values (0), (2);
 | |
| update t1 left join t2 on a > b set b= 2 order by b;
 | |
| 
 | |
| # cleanup
 | |
| drop table t1, t2;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-17091 Assertion `old_part_id == m_last_part' failed in
 | |
| --echo # ha_partition::update_row or `part_id == m_last_part' in
 | |
| --echo # ha_partition::delete_row upon UPDATE/DELETE after dropping versioning
 | |
| --echo #
 | |
| create or replace table t1 (pk int primary key, f int) engine=innodb
 | |
|         with system versioning
 | |
|         partition by key() partitions 2;
 | |
| insert into t1 values (1,10),(2,20);
 | |
| --echo # expected to hit same partition
 | |
| select * from t1 partition (p0);
 | |
| alter table t1 drop system versioning;
 | |
| 
 | |
| --echo # 1 and 2 are expected to be in different partitions
 | |
| select * from t1 partition(p0);
 | |
| select * from t1 partition(p1);
 | |
| 
 | |
| update t1 set f=pk;
 | |
| delete from t1;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-22413 Server hangs upon UPDATE/DELETE on a view reading from versioned partitioned table
 | |
| --echo #
 | |
| create or replace table t1 (f char(6)) engine innodb with system versioning;
 | |
| 
 | |
| insert into t1 values (null);
 | |
| update t1 set f= 'foo';
 | |
| update t1 set f= 'bar';
 | |
| --echo # You see warning above ^
 | |
| 
 | |
| create or replace view v1 as select * from t1 for system_time all;
 | |
| --error ER_TABLE_NOT_LOCKED_FOR_WRITE
 | |
| update v1 set f = '';
 | |
| 
 | |
| create or replace table t1 (f char(6)) engine innodb with system versioning
 | |
| partition by system_time limit 1
 | |
| (partition p1 history, partition p2 history, partition pn current);
 | |
| 
 | |
| insert into t1 values (null);
 | |
| update t1 set f= 'foo';
 | |
| update t1 set f= 'bar';
 | |
| 
 | |
| create or replace view v1 as select * from t1 for system_time all;
 | |
| --error ER_TABLE_NOT_LOCKED_FOR_WRITE
 | |
| update v1 set f= '';
 | |
| --error ER_TABLE_NOT_LOCKED_FOR_WRITE
 | |
| delete from v1;
 | |
| 
 | |
| # cleanup
 | |
| drop view v1;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-22112 Assertion `tab_part_info->part_type == RANGE_PARTITION || tab_part_info->part_type == LIST_PARTITION' failed in prep_alter_part_table
 | |
| --echo #
 | |
| 
 | |
| create table t1 (a int) with system versioning partition by system_time;
 | |
| drop table t1;
 | |
| 
 | |
| create table t1 (a int) with system versioning partition by system_time
 | |
| (partition p1 history, partition pn current);
 | |
| --error ER_PARTITION_WRONG_TYPE
 | |
| alter table t1 add partition (partition p2);
 | |
| 
 | |
| --echo # MDEV-17891 Assertion failures in select_insert::abort_result_set and
 | |
| --echo #            mysql_load upon attempt to replace into a full table
 | |
| 
 | |
| --let $max_heap_table_size_orig= `select @@max_heap_table_size;`
 | |
| set @@max_heap_table_size= 1024*1024;
 | |
| create or replace table t1 (
 | |
|   pk integer auto_increment,
 | |
|   primary key (pk),
 | |
|   f varchar(45000)
 | |
| ) charset=latin1 with system versioning engine=memory
 | |
|   partition by system_time interval 1 year (partition p1 history,
 | |
|                                             partition pn current);
 | |
| 
 | |
| --echo # fill the table until full
 | |
| insert into t1 () values (),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),();
 | |
| --error ER_RECORD_FILE_FULL
 | |
| insert into t1 (f) select f from t1;
 | |
| --echo # leave space for exactly one record in current partition
 | |
| delete from t1 where pk = 1;
 | |
| --echo # copy all data into history partition
 | |
| replace into t1 select * from t1;
 | |
| --error ER_RECORD_FILE_FULL
 | |
| replace into t1 select * from t1;
 | |
| 
 | |
| create or replace table t1 (
 | |
|   pk integer auto_increment,
 | |
|   primary key (pk),
 | |
|   f varchar(45000)
 | |
| ) charset=latin1 with system versioning engine=memory
 | |
|   partition by system_time interval 1 year (partition p1 history,
 | |
|                                             partition pn current);
 | |
| 
 | |
| insert into t1 () values (),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),();
 | |
| 
 | |
| select * into outfile 'MDEV-17891.data' from t1;
 | |
| load data infile 'MDEV-17891.data' replace into table t1;
 | |
| --error ER_RECORD_FILE_FULL
 | |
| load data infile 'MDEV-17891.data' replace into table t1;
 | |
| --error ER_RECORD_FILE_FULL
 | |
| load data infile 'MDEV-17891.data' replace into table t1;
 | |
| 
 | |
| # Cleanup
 | |
| --remove_file $datadir/test/MDEV-17891.data
 | |
| eval set @@max_heap_table_size= $max_heap_table_size_orig;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-22178 Assertion `info->alias.str' failed in partition_info::check_partition_info instead of ER_VERS_WRONG_PARTS
 | |
| --echo #
 | |
| create or replace table t1 (a int) with system versioning;
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| alter table t1 partition by system_time (partition pn current);
 | |
| # Cleanup
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-22247 History partition overflow leads to wrong SELECT result
 | |
| --echo #
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 1 hour
 | |
| (partition p0 history, partition p1 history, partition pn current);
 | |
| 
 | |
| insert into t1 values (0);
 | |
| update t1 set x= x + 1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:01');
 | |
| update t1 set x= x + 1;
 | |
| 
 | |
| select *, row_start, row_end from t1 for system_time as of '2000-01-01 02:00:00';
 | |
| --replace_column 10 #
 | |
| explain partitions select * from t1 for system_time as of '2000-01-01 02:00:00';
 | |
| --replace_column 5 # 10 # 11 #
 | |
| explain partitions select * from t1;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-27244 Table corruption upon adding serial data type
 | |
| --echo #
 | |
| create table t1 (f int, key(f)) with system versioning
 | |
| partition by system_time limit 10 (partition p0 history, partition pn current);
 | |
| alter table t1 add x serial;
 | |
| alter table t1 add partition (partition p1 history);
 | |
| alter table t1 add partition (partition p2 history);
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-27217 DELETE partition selection doesn't work for history partitions
 | |
| --echo #
 | |
| create table t1 (f char) with system versioning
 | |
| partition by system_time limit 10 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition p2 history,
 | |
|   partition pn current);
 | |
| 
 | |
| --error ER_VERS_NOT_ALLOWED
 | |
| delete from t1 partition (p1);
 | |
| --error ER_VERS_NOT_ALLOWED
 | |
| delete from t1 partition (p0, pn);
 | |
| --error ER_VERS_NOT_ALLOWED
 | |
| delete from t1 partition (p0, p1);
 | |
| --error ER_VERS_NOT_ALLOWED
 | |
| delete from t1 partition (p0, p1, pn);
 | |
| drop table t1;
 | |
| 
 | |
| set timestamp=unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| set timestamp=unix_timestamp('2000-01-02 00:00:00');
 | |
| insert t1 values (1);
 | |
| --error ER_VERS_NOT_ALLOWED
 | |
| delete from t1 partition (p0, pn);
 | |
| --error ER_VERS_NOT_ALLOWED
 | |
| delete from t1 partition (p0, p1, pn);
 | |
| lock tables t1 write;
 | |
| --error ER_VERS_NOT_ALLOWED
 | |
| delete from t1 partition (p0, pn);
 | |
| delete from t1;
 | |
| unlock tables;
 | |
| drop table t1;
 | |
| set timestamp= default;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-25546 LIMIT partitioning does not respect ROLLBACK
 | |
| --echo #
 | |
| create or replace table t1 (pk int primary key)
 | |
| with system versioning engine innodb
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| insert into t1 select seq from seq_1_to_90;
 | |
| 
 | |
| start transaction;
 | |
| # Puts 80 rows into p0
 | |
| replace into t1 select seq from seq_1_to_80;
 | |
| # Puts another 70 rows into p0
 | |
| replace into t1 select seq from seq_1_to_70;
 | |
| # Puts 60 rows into p1
 | |
| replace into t1 select seq from seq_1_to_60;
 | |
| 
 | |
| select partition_name, table_rows
 | |
| from information_schema.partitions
 | |
| where table_name = 't1';
 | |
| rollback;
 | |
| 
 | |
| select partition_name, table_rows
 | |
| from information_schema.partitions
 | |
| where table_name = 't1';
 | |
| 
 | |
| # Should put 10 rows into the empty partition p0
 | |
| replace into t1 select seq from seq_1_to_10;
 | |
| select partition_name, table_rows
 | |
| from information_schema.partitions
 | |
| where table_name = 't1';
 | |
|  # Cleanup
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-28271 Assertion on TRUNCATE PARTITION for PARTITION BY SYSTEM_TIME
 | |
| --echo #
 | |
| create table t1 (x int) with system versioning
 | |
| partition by system_time limit 1 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition p2 history, # p2 just disables warning about p1 partition full
 | |
|   partition pn current);
 | |
| 
 | |
| insert into t1 values (0);
 | |
| update t1 set x= x + 1;
 | |
| update t1 set x= x + 1;
 | |
| 
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (pn);
 | |
| 
 | |
| delete from t1;
 | |
| delete history from t1;
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (pn);
 | |
| 
 | |
| insert into t1 values (0);
 | |
| update t1 set x= x + 1;
 | |
| update t1 set x= x + 1;
 | |
| 
 | |
| --echo # TRUNCATE PARTITION ALL does the same
 | |
| alter table t1 truncate partition all;
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (pn);
 | |
| 
 | |
| insert into t1 values (0);
 | |
| update t1 set x= x + 1;
 | |
| update t1 set x= x + 1;
 | |
| 
 | |
| --echo # TRUNCATE PARTITION deletes data from HISTORY partition
 | |
| alter table t1 truncate partition p1;
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (pn);
 | |
| 
 | |
| --echo # or from CURRENT partition
 | |
| alter table t1 truncate partition pn;
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (pn);
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-20077 Warning on full history partition is delayed until next DML statement
 | |
| --echo #
 | |
| --echo # DELETE
 | |
| create table t1 (x int) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| insert into t1 select seq from seq_0_to_200;
 | |
| 
 | |
| --echo # p0 is filled with 100 records (no warnings):
 | |
| delete from t1 where x <= 99;
 | |
| --echo # p1 is filled with 1 + 100 records (warning is printed):
 | |
| delete from t1 where x <= 100;
 | |
| delete from t1;
 | |
| --echo # You see warning above ^
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop table t1;
 | |
| 
 | |
| --echo # DELETE under LOCK TABLES
 | |
| create table t1 (x int) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| insert into t1 select seq from seq_0_to_200;
 | |
| 
 | |
| lock tables t1 write;
 | |
| --echo # (LOCK TABLES) p0 is filled with 100 records (no warnings):
 | |
| delete from t1 where x <= 99;
 | |
| --echo # (LOCK TABLES) p1 is filled with 1 + 100 records (warning is printed):
 | |
| delete from t1 where x <= 100;
 | |
| delete from t1;
 | |
| --echo # You see warning above ^
 | |
| unlock tables;
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop table t1;
 | |
| 
 | |
| --echo # DELETE multitable
 | |
| create table t1 (x int) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| create table t2 (y int);
 | |
| 
 | |
| insert into t1 select seq from seq_0_to_200;
 | |
| insert into t2 select seq from seq_0_to_3;
 | |
| delete t1, t2 from t1 join t2 where x < 50 and y = 0;
 | |
| delete t1, t2 from t1 join t2 where x < 100 and y = 1;
 | |
| delete t1, t2 from t1 join t2 where x < 150 and y = 2;
 | |
| delete t1, t2 from t1 join t2;
 | |
| --echo # You see warning above ^
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop table t1;
 | |
| 
 | |
| --echo # UPDATE
 | |
| create table t1 (x int) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| insert into t1 select seq from seq_0_to_49;
 | |
| 
 | |
| update t1 set x= x + 1;
 | |
| update t1 set x= x + 1;
 | |
| update t1 set x= x + 1;
 | |
| update t1 set x= x + 1;
 | |
| --echo # You see warning above ^
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop tables t1, t2;
 | |
| 
 | |
| --echo # UPDATE multitable
 | |
| create table t1 (x int) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| create table t2 (y int);
 | |
| 
 | |
| insert into t1 select seq from seq_0_to_49;
 | |
| insert into t2 values (5);
 | |
| 
 | |
| update t1, t2 set x= x + 1;
 | |
| update t1, t2 set x= x + 1;
 | |
| update t1, t2 set x= x + 1;
 | |
| update t1, t2 set x= x + 1;
 | |
| --echo # You see warning above ^
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop tables t1, t2;
 | |
| 
 | |
| --echo # INSERT .. ON DUPLICATE KEY UPDATE (ODKU)
 | |
| create table t1 (x int primary key) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| insert into t1 select seq from seq_0_to_100;
 | |
| 
 | |
| delete from t1 where x <= 99;
 | |
| insert into t1 values (100) on duplicate key update x= 400;
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop table t1;
 | |
| 
 | |
| --echo # INSERT .. SELECT .. ON DUPLICATE KEY UPDATE (ODKU)
 | |
| create table t1 (x int primary key) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| create table t2 (y int);
 | |
| insert into t2 values (100);
 | |
| insert into t1 select seq from seq_0_to_100;
 | |
| 
 | |
| delete from t1 where x <= 99;
 | |
| insert into t1 select * from t2 on duplicate key update x= 500;
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop tables t1, t2;
 | |
| 
 | |
| --echo # REPLACE
 | |
| create table t1 (x int primary key) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| insert into t1 select seq from seq_0_to_100;
 | |
| 
 | |
| delete from t1 where x < 99;
 | |
| replace t1 values (100);
 | |
| replace t1 values (100);
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop table t1;
 | |
| 
 | |
| --echo # LOAD DATA .. REPLACE
 | |
| create table t1 (x int primary key) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| insert into t1 select seq from seq_0_to_49;
 | |
| select x into outfile 'MDEV-20077.data' from t1;
 | |
| 
 | |
| load data infile 'MDEV-20077.data' replace into table t1 (x);
 | |
| load data infile 'MDEV-20077.data' replace into table t1 (x);
 | |
| load data infile 'MDEV-20077.data' replace into table t1 (x);
 | |
| load data infile 'MDEV-20077.data' replace into table t1 (x);
 | |
| --echo # You see warning above ^
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop table t1;
 | |
| --remove_file $datadir/test/MDEV-20077.data
 | |
| 
 | |
| --echo # REPLACE .. SELECT
 | |
| create table t1 (x int primary key) with system versioning
 | |
| partition by system_time limit 100 (
 | |
|   partition p0 history,
 | |
|   partition p1 history,
 | |
|   partition pn current);
 | |
| 
 | |
| insert into t1 select seq from seq_0_to_49;
 | |
| replace t1 select * from t1;
 | |
| replace t1 select * from t1;
 | |
| replace t1 select * from t1;
 | |
| replace t1 select * from t1;
 | |
| --echo # You see warning above ^
 | |
| 
 | |
| select count(*) from t1 partition (p0);
 | |
| select count(*) from t1 partition (p1);
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-28552 Assertion `inited==RND' failed in handler::ha_rnd_end
 | |
| --echo #
 | |
| create table tcount (c int unsigned);
 | |
| insert into tcount values (0);
 | |
| 
 | |
| create table t (f int) with system versioning
 | |
| partition by system_time limit 1000
 | |
| (partition p1 history, partition pn current);
 | |
| insert into t values (1),(2);
 | |
| create trigger tr before insert on t for each row update tcount set c = c + 1;
 | |
| 
 | |
| insert into t select * from t;
 | |
| 
 | |
| # cleanup
 | |
| drop table tcount, t;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-19569 Assertion `table_list->table' failed in find_field_in_table_ref and Assertion `table_ref->table || table_ref->view' in Field_iterator_table_ref::set_field_iterator
 | |
| --echo #
 | |
| set timestamp=unix_timestamp('2000-01-01 00:00:00');
 | |
| create table t1 (i int); 
 | |
| create table t2 (i int); 
 | |
|  
 | |
| --error ER_SUBQUERIES_NOT_SUPPORTED
 | |
| alter table t1 partition by system_time 
 | |
|   interval (select i from t2) day (partition p1 history, partition pn current);
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| --error ER_SUBQUERIES_NOT_SUPPORTED
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time 
 | |
|   interval (select i from t2) day (partition p1 history, partition pn current);
 | |
| 
 | |
| --error ER_PART_WRONG_VALUE
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time
 | |
|   interval "hello" day (partition p1 history, partition pn current);
 | |
| 
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time
 | |
|   interval 3.893 day (partition p1 history, partition pn current);
 | |
| 
 | |
| drop table t1, t2;
 | |
| 
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time interval "3-11" year_month (partition p1 history, partition pn current);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| drop table t1;
 | |
| 
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time interval "3 11" day_hour (partition p1 history, partition pn current);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| drop table t1;
 | |
| 
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time interval "3 11:12" day_minute (partition p1 history, partition pn current);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| drop table t1;
 | |
| 
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time interval "3 11:12:13" day_second (partition p1 history, partition pn current);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| drop table t1;
 | |
| 
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time interval "11:12" hour_minute (partition p1 history, partition pn current);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| drop table t1;
 | |
| 
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time interval "11:12:13" hour_second (partition p1 history, partition pn current);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| drop table t1;
 | |
| 
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time interval "12:13" minute_second (partition p1 history, partition pn current);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| drop table t1;
 | |
| 
 | |
| --error ER_PART_WRONG_VALUE
 | |
| create table t1 (id int) with system versioning
 | |
|   partition by system_time interval "12:13.123" minute_microsecond (partition p1 history, partition pn current);
 | |
| 
 | |
| --echo #
 | |
| --echo # End of 10.3 tests
 | |
| --echo #
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-22283 Server crashes in key_copy or unexpected error 156: The table already existed in the storage engine
 | |
| --echo #
 | |
| create table t1 (a int primary key) engine=aria page_checksum=0
 | |
| with system versioning
 | |
| partition by system_time (partition p1 history, partition pn current);
 | |
| 
 | |
| alter table t1 add partition (partition p2 history);
 | |
| show table status;
 | |
| drop table t1;
 | |
| 
 | |
| create table t1 (b int) engine=aria row_format=dynamic with system versioning
 | |
| partition by system_time (partition p1 history, partition pn current);
 | |
| insert into t1 values (1);
 | |
| replace into t1 values (1);
 | |
| 
 | |
| # cleanup
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-18794 Assertion `!m_innodb' failed in ha_partition::cmp_ref upon SELECT from partitioned table
 | |
| --echo #
 | |
| create or replace table t1 (pk int auto_increment, i int, c char(1), primary key (pk), key(i))
 | |
| engine=innodb with system versioning partition by key() partitions 2;
 | |
| insert into t1 (i, c) values (1, 'a'), (2, 'b'), (null, 'c'), (null, 'b');
 | |
| alter table t1 drop system versioning;
 | |
| replace into t1 select * from t1;
 | |
| select * from t1 where i > 0 or pk = 1000 limit 1;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # End of 10.4 tests
 | |
| --echo #
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-22153 ALTER add default history partitions makes table inaccessible
 | |
| --echo #
 | |
| create or replace table t1 (x int) with system versioning partition by system_time;
 | |
| alter table t1 add partition partitions 1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| alter table t1 add partition partitions 2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| alter table t1 add partition partitions 3;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| drop tables t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-22207 Drop default history partitions renders table inaccessible
 | |
| --echo #
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time limit 1 partitions 5;
 | |
| 
 | |
| alter table t1 drop partition p0, p2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| alter table t1 add partition partitions 1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| drop tables t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-22155 ALTER add default history partitions name clash on non-default partitions
 | |
| --echo #
 | |
| set timestamp= default;
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time limit 1
 | |
| (partition p2 history, partition p8 history, partition pn current);
 | |
| alter table t1 add partition partitions 1;
 | |
| alter table t1 add partition partitions 2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| alter table t1 add partition partitions 8;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| drop tables t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-27328 Change of SYSTEM_TIME partitioning options is not possible without data copy
 | |
| --echo #
 | |
| create or replace table t1 (f int) with system versioning
 | |
| partition by hash(f);
 | |
| alter table t1 partition by system_time;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| create or replace table t1 (f int) with system versioning
 | |
| partition by system_time;
 | |
| alter table t1 partition by hash(f);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| create or replace table t1 (x int) with system versioning;
 | |
| alter table t1 partition by system_time;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time limit 100 partitions 4;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| alter table t1 add partition partitions 2;
 | |
| alter table t1 partition by system_time;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| alter table t1 partition by system_time limit 33;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| insert t1 values (0);
 | |
| set timestamp= unix_timestamp('2000-01-01 00:10:00');
 | |
| update t1 set x= x + 1;
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| update t1 set x= x + 1;
 | |
| set timestamp= unix_timestamp('2000-01-01 01:30:00');
 | |
| update t1 set x= x + 1;
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| update t1 set x= x + 1;
 | |
| 
 | |
| # When we switch to INTERVAL we must reorganize partitions.
 | |
| # Otherwise pruning won't work correctly.
 | |
| alter table t1 partition by system_time interval 1 hour
 | |
| starts '2000-01-01 00:00:00';
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (p2);
 | |
| select * from t1 partition (pn);
 | |
| set timestamp= default;
 | |
| 
 | |
| # When we switch to LIMIT we probably don't want to reorganize old partitions.
 | |
| # Note: reorganize for LIMIT is broken, it pushes all history into first partition.
 | |
| # TODO: MDEV-27337
 | |
| alter table t1 partition by system_time limit 1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| update t1 set x= x + 1;
 | |
| update t1 set x= x + 1;
 | |
| --echo # You see warning above ^
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (p2);
 | |
| select * from t1 partition (p3);
 | |
| select * from t1 partition (p4);
 | |
| select * from t1 partition (pn);
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| --echo # End of 10.6 tests
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-22166 MIGRATE PARTITION: move out partition into a table
 | |
| --echo #
 | |
| create or replace table t1 (x int)
 | |
| with system versioning
 | |
| partition by range(x) (
 | |
|   partition p1 values less than (10),
 | |
|   partition p2 values less than (20),
 | |
|   partition p3 values less than (30),
 | |
|   partition p4 values less than (40),
 | |
|   partition p5 values less than (50),
 | |
|   partition pn values less than maxvalue);
 | |
| 
 | |
| insert into t1 values (2), (12), (22), (32), (42), (52);
 | |
| update t1 set x= x + 1;
 | |
| 
 | |
| alter table t1 convert partition p2 to table tp2;
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table tp2;
 | |
| select * from tp2;
 | |
| select * from tp2 for system_time all order by x;
 | |
| 
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table t1;
 | |
| select * from t1 order by x;
 | |
| select * from t1 for system_time all order by x;
 | |
| 
 | |
| --echo # SP
 | |
| create or replace procedure sp()
 | |
| alter table t1 convert partition p3 to table tp3;
 | |
| call sp;
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table tp3;
 | |
| select * from tp3;
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table t1;
 | |
| select * from t1 order by x;
 | |
| drop table tp3;
 | |
| --error ER_PARTITION_DOES_NOT_EXIST
 | |
| call sp;
 | |
| --error ER_PARTITION_DOES_NOT_EXIST
 | |
| call sp;
 | |
| drop procedure sp;
 | |
| 
 | |
| --echo # LOCK TABLES, PS, SP
 | |
| create or replace procedure sp()
 | |
| alter table t1 convert partition p4 to table tp4;
 | |
| lock tables t1 write;
 | |
| prepare stmt from 'call sp';
 | |
| execute stmt;
 | |
| 
 | |
| # TODO: don't unlock here (see above TODO)
 | |
| unlock tables;
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table tp4;
 | |
| select * from tp4;
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table t1;
 | |
| select * from t1 order by x;
 | |
| drop table tp4;
 | |
| lock tables t1 write;
 | |
| --error ER_PARTITION_DOES_NOT_EXIST
 | |
| execute stmt;
 | |
| --error ER_PARTITION_DOES_NOT_EXIST
 | |
| call sp;
 | |
| drop prepare stmt;
 | |
| unlock tables;
 | |
| drop procedure sp;
 | |
| unlock tables;
 | |
| 
 | |
| drop tables t1, tp2;
 | |
| 
 | |
| --echo # System-versioned tables (SYSTEM_TIME LIMIT)
 | |
| 
 | |
| create or replace table t1 (
 | |
|   x int,
 | |
|   row_start timestamp(6) as row start invisible,
 | |
|   row_end timestamp(6) as row end invisible,
 | |
|   period for system_time(row_start, row_end)
 | |
| ) with system versioning
 | |
| partition by system_time limit 1 partitions 4;
 | |
| 
 | |
| insert into t1 values (2), (12), (22);
 | |
| update t1 set x= x + 1 where x = 2;
 | |
| update t1 set x= x + 1 where x = 12;
 | |
| update t1 set x= x + 1 where x = 22;
 | |
| 
 | |
| select * from t1 partition (p1);
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| alter table t1 convert partition pn to table tp1;
 | |
| alter table t1 convert partition p1 to table tp1;
 | |
| 
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table tp1;
 | |
| select * from tp1;
 | |
| select * from tp1 for system_time all;
 | |
| 
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table t1;
 | |
| select * from t1 order by x;
 | |
| select * from t1 for system_time all order by x;
 | |
| 
 | |
| drop tables t1, tp1;
 | |
| 
 | |
| --echo # System-versioned tables (SYSTEM_TIME INTERVAL)
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (
 | |
|   x int,
 | |
|   row_start timestamp(6) as row start invisible,
 | |
|   row_end timestamp(6) as row end invisible,
 | |
|   period for system_time(row_start, row_end)
 | |
| ) with system versioning
 | |
| partition by system_time interval 1 hour partitions 4;
 | |
| 
 | |
| insert into t1 values (2), (12), (22);
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:01');
 | |
| update t1 set x= x + 1 where x = 2;
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| update t1 set x= x + 1 where x = 12;
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| update t1 set x= x + 1 where x = 22;
 | |
| 
 | |
| select * from t1 partition (p0);
 | |
| select * from t1 partition (p1);
 | |
| select * from t1 partition (p2);
 | |
| --error ER_VERS_DROP_PARTITION_INTERVAL
 | |
| alter table t1 convert partition p1 to table tp1;
 | |
| alter table t1 convert partition p0 to table tp0;
 | |
| alter table t1 convert partition p1 to table tp1;
 | |
| --error ER_VERS_WRONG_PARTS
 | |
| alter table t1 convert partition p2 to table tp2;
 | |
| 
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table tp0;
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table tp1;
 | |
| select * from tp0;
 | |
| select * from tp1;
 | |
| select * from tp0 for system_time all;
 | |
| select * from tp1 for system_time all;
 | |
| 
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table t1;
 | |
| select * from t1;
 | |
| select * from t1 for system_time all order by x;
 | |
| 
 | |
| drop tables t1, tp0, tp1;
 | |
| 
 | |
| --echo # System-versioned tables (implicit)
 | |
| 
 | |
| create or replace table t1(x int) with system versioning
 | |
| partition by system_time limit 1 partitions 3;
 | |
| 
 | |
| alter table t1 convert partition p1 to table tp1;
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table tp1;
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table t1;
 | |
| 
 | |
| drop tables t1, tp1;
 | |
| 
 | |
| if (!$MTR_COMBINATION_HEAP)
 | |
| {
 | |
| --echo # Complex table
 | |
| create or replace table t1 (
 | |
|   x int primary key auto_increment,
 | |
|   t timestamp(6) default '2001-11-11 11:11:11',
 | |
|   b blob(4096) compressed null,
 | |
|   c varchar(1033) character set utf8 not null,
 | |
|   u int,
 | |
|   unique key (x, u),
 | |
|   m enum('a', 'b', 'c') not null default 'a' comment 'absolute',
 | |
|   i1 tinyint, i2 smallint, i3 bigint,
 | |
|   index three(i1, i2, i3),
 | |
|   v1 timestamp(6) generated always as (t + interval 1 day),
 | |
|   v2 timestamp(6) generated always as (t + interval 1 month) stored,
 | |
|   s timestamp(6) as row start,
 | |
|   e timestamp(6) as row end,
 | |
|   period for system_time (s, e),
 | |
|   ps date, pe date,
 | |
|   period for app_time (ps, pe),
 | |
|   constraint check_constr check (u > -1))
 | |
| with system versioning default charset=ucs2
 | |
| partition by range(x) (
 | |
|   partition p0 values less than (10),
 | |
|   partition p1 values less than (20),
 | |
|   partition pn values less than maxvalue);
 | |
| 
 | |
| alter table t1 convert partition p1 to table tp1;
 | |
| 
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table tp1;
 | |
| --replace_result $default_engine X ' PAGE_CHECKSUM=1' ''
 | |
| show create table t1;
 | |
| 
 | |
| drop tables t1, tp1;
 | |
| }
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-29841 Partition by system_time can be converted into table but not back
 | |
| --echo #
 | |
| create or replace table t (a int) with system versioning
 | |
| partition by system_time limit 10 partitions 3;
 | |
| alter table t convert partition p0 to table tp;
 | |
| --error ER_ONLY_ON_RANGE_LIST_PARTITION
 | |
| alter table t convert table tp to partition p0;
 | |
| drop tables t, tp;
 | |
| 
 | |
| --echo #
 | |
| --echo # End of 10.7 tests
 | |
| --echo #
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-17554 Auto-create new partition for system versioned tables
 | |
| --echo #            with history partitioned by INTERVAL/LIMIT
 | |
| --echo #
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time limit 1 auto;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --echo # Turn off AUTO
 | |
| alter table t1 partition by system_time limit 1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --echo # Get AUTO back
 | |
| alter table t1 partition by system_time limit 1 auto;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| insert into t1 values (1);
 | |
| 
 | |
| create or replace table t2 (y int);
 | |
| insert into t2 values (2);
 | |
| 
 | |
| insert into t1 select * from t2;
 | |
| insert into t2 select * from t1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| --echo # Too many partitions error
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 1 hour auto;
 | |
| set timestamp= unix_timestamp('2001-01-01 00:01:00');
 | |
| --error ER_VERS_HIST_PART_FAILED
 | |
| update t1 set x= x + 1;
 | |
| show warnings;
 | |
| 
 | |
| --echo # Auto-create failed error
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning engine innodb
 | |
| partition by system_time interval 1 hour auto;
 | |
| 
 | |
| insert into t1 values (1);
 | |
| 
 | |
| call mtr.add_suppression("rror number .*(File exists|file operation)");
 | |
| call mtr.add_suppression("InnoDB: Cannot create file");
 | |
| 
 | |
| --let $datadir= `select @@datadir`
 | |
| --let $dummy= $datadir/test/t1#P#p1.ibd
 | |
| --write_file $dummy
 | |
| EOF
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| --error ER_GET_ERRNO
 | |
| update t1 set x= x + 2;
 | |
| show warnings;
 | |
| --remove_file $dummy
 | |
| 
 | |
| --echo # Partition overflow error and manual fix
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 1 hour;
 | |
| 
 | |
| insert into t1 values (440);
 | |
| set timestamp= unix_timestamp('2000-01-01 00:10:00');
 | |
| update t1 set x= x + 1;
 | |
| 
 | |
| --echo # Check how pruning boundaries work
 | |
| --replace_column 5 # 10 # 11 #
 | |
| explain partitions select * from t1 for system_time as of '2000-01-01 00:59:58';
 | |
| --replace_column 5 # 10 # 11 #
 | |
| explain partitions select * from t1 for system_time as of '2000-01-01 00:59:59';
 | |
| --replace_column 5 # 10 # 11 #
 | |
| explain partitions select * from t1 for system_time as of '2000-01-01 01:00:00';
 | |
| select * from t1 for system_time as of '2000-01-01 00:09:59';
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| update t1 set x= x + 1;
 | |
| 
 | |
| select * from t1 for system_time as of '2000-01-01 01:00:00';
 | |
| select * from t1 partition (p0) order by x;
 | |
| 
 | |
| --echo # Here is how manual fix works: just add new partitions there
 | |
| alter table t1 add partition partitions 3;
 | |
| select * from t1 for system_time as of '2000-01-01 01:00:00';
 | |
| select * from t1 partition (p0) order by x;
 | |
| 
 | |
| --echo # Check pruning after ALTER
 | |
| --replace_column 5 # 10 # 11 #
 | |
| explain partitions select * from t1 for system_time as of '2000-01-01 00:59:58';
 | |
| --replace_column 5 # 10 # 11 #
 | |
| explain partitions select * from t1 for system_time as of '2000-01-01 00:59:59';
 | |
| --replace_column 5 # 10 # 11 #
 | |
| explain partitions select * from t1 for system_time as of '2000-01-01 01:00:00';
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| --enable_info
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 3600 second
 | |
| starts '2000-01-01 00:00:00' auto partitions 3;
 | |
| 
 | |
| insert into t1 values (1);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| update t1 set x= x + 1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 03:00:00');
 | |
| update t1 set x= x + 2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 1 hour auto (
 | |
|     partition p1 history,
 | |
|     partition p3 history,
 | |
|     partition pn current);
 | |
| 
 | |
| insert into t1 values (1);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| update t1 set x= x + 3;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 03:00:00');
 | |
| update t1 set x= x + 4;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 04:00:00');
 | |
| lock tables t1 write;
 | |
| update t1 set x= x + 5;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| unlock tables;
 | |
| set timestamp= default;
 | |
| 
 | |
| --echo # Couple of more LOCK TABLES cases
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time limit 1 auto;
 | |
| lock tables t1 write;
 | |
| insert into t1 values (1);
 | |
| update t1 set x= x + 1;
 | |
| update t1 set x= x + 2;
 | |
| update t1 set x= x + 3;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| unlock tables;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| --echo # Overflow prevention under LOCK TABLES
 | |
| create or replace table t1 (x int)
 | |
| with system versioning partition by system_time
 | |
| limit 10 auto;
 | |
| 
 | |
| insert into t1 values (1), (2), (3), (4), (5), (6), (7), (8), (9);
 | |
| update t1 set x= x + 10;
 | |
| 
 | |
| lock tables t1 write;
 | |
| update t1 set x= 1 where x = 11;
 | |
| update t1 set x= 2 where x = 12;
 | |
| update t1 set x= 3 where x = 13;
 | |
| unlock tables;
 | |
| 
 | |
| select count(x) from t1 partition (p0);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| drop tables t1;
 | |
| 
 | |
| --echo # Test VIEW, LOCK TABLES
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 1 hour auto;
 | |
| create or replace view v1 as select * from t1;
 | |
| 
 | |
| insert into t1 values (1);
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| update v1 set x= x + 2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| lock tables v1 write;
 | |
| update v1 set x= x + 3;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| unlock tables;
 | |
| 
 | |
| drop view v1;
 | |
| drop tables t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 1 hour auto partitions 3;
 | |
| 
 | |
| create or replace table t2 (y int) with system versioning
 | |
| partition by system_time interval 1 hour auto;
 | |
| 
 | |
| insert into t1 values (1);
 | |
| insert into t2 values (2);
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| update t1, t2 set x= x + 1, y= y + 1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t2;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| update t1, t2 set x= x + 1, y= y + 1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t2;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 03:00:00');
 | |
| update t1, t2 set t1.x= 0 where t1.x< t2.y;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| # Multiupdate_prelocking_strategy::handle_end() is processed after table open.
 | |
| # For PS it is possible to skip unneeded auto-creation because the above happens at
 | |
| # prepare stage and auto-creation is done at execute stage.
 | |
| --replace_result $default_engine DEFAULT_ENGINE 'PARTITIONS 4' 'PARTITIONS ok' 'PARTITIONS 5' 'PARTITIONS ok'
 | |
| show create table t2;
 | |
| 
 | |
| drop tables t1, t2;
 | |
| 
 | |
| --echo # PS, SP, LOCK TABLES
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 1 hour auto;
 | |
| 
 | |
| insert into t1 values (1);
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| execute immediate 'update t1 set x= x + 5';
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| prepare s from 'update t1 set x= x + 6';
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| execute s; execute s;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 03:00:00');
 | |
| lock tables t1 write;
 | |
| execute s; execute s;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| unlock tables;
 | |
| drop prepare s;
 | |
| 
 | |
| create procedure sp() update t1 set x= x + 7;
 | |
| set timestamp= unix_timestamp('2000-01-01 04:00:00');
 | |
| call sp; call sp;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| set timestamp= unix_timestamp('2000-01-01 05:00:00');
 | |
| lock tables t1 write;
 | |
| call sp; call sp;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| unlock tables;
 | |
| drop procedure sp;
 | |
| 
 | |
| set timestamp= unix_timestamp('2001-01-01 00:00:00');
 | |
| create or replace table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 day starts '2001-01-01 00:00:00';
 | |
| insert into t1 values (0);
 | |
| set timestamp= unix_timestamp('2001-01-01 00:00:01');
 | |
| prepare s from 'update t1 set i= i + 1';
 | |
| execute s;
 | |
| set timestamp= unix_timestamp('2001-01-02 00:00:01');
 | |
| execute s;
 | |
| drop prepare s;
 | |
| 
 | |
| # Because of blobs:
 | |
| if (!$MTR_COMBINATION_HEAP)
 | |
| {
 | |
| --echo # Complex table
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (
 | |
|   x int primary key auto_increment,
 | |
|   t timestamp(6) default '2001-11-11 11:11:11',
 | |
|   b blob(4096) compressed null,
 | |
|   c varchar(1033) character set utf8 not null,
 | |
|   u int unique,
 | |
|   m enum('a', 'b', 'c') not null default 'a' comment 'absolute',
 | |
|   i1 tinyint, i2 smallint, i3 bigint,
 | |
|   index three(i1, i2, i3),
 | |
|   v1 timestamp(6) generated always as (t + interval 1 day),
 | |
|   v2 timestamp(6) generated always as (t + interval 1 month) stored,
 | |
|   s timestamp(6) as row start,
 | |
|   e timestamp(6) as row end,
 | |
|   period for system_time (s, e),
 | |
|   ps date, pe date,
 | |
|   period for app_time (ps, pe),
 | |
|   constraint check_constr check (u > -1))
 | |
| with system versioning default charset=ucs2
 | |
| partition by system_time interval 1 hour auto (
 | |
|     partition p2 history,
 | |
|     partition pn current);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| insert into t1 (x, c, u, i1, i2, i3, ps, pe)
 | |
| values (1, 'cc', 0, 1, 2, 3, '1999-01-01', '2000-01-01');
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| update t1 set x= x + 8;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| update t1 set x= x - 8;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| }
 | |
| --disable_info
 | |
| 
 | |
| --echo # INSERT .. ON DUPLICATE KEY UPDATE (ODKU)
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int primary key) with system versioning
 | |
| partition by system_time interval 1 hour auto;
 | |
| insert into t1 values (1);
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| insert into t1 values (1) on duplicate key update x= x + 1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| --echo # LOAD DATA .. REPLACE
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int primary key) with system versioning
 | |
| partition by system_time interval 1 hour auto;
 | |
| 
 | |
| insert t1 values (1), (2), (3);
 | |
| select x into outfile 'MDEV-17554.data' from t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| load data infile 'MDEV-17554.data' replace into table t1 (x);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --remove_file $datadir/test/MDEV-17554.data
 | |
| 
 | |
| --echo # Concurrent DML
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 1 hour auto partitions 3;
 | |
| 
 | |
| insert into t1 values (1);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| --connect con8, localhost, root
 | |
| --connect con7, localhost, root
 | |
| --connect con6, localhost, root
 | |
| --connect con5, localhost, root
 | |
| --connect con4, localhost, root
 | |
| --connect con3, localhost, root
 | |
| --connect con2, localhost, root
 | |
| --connect con1, localhost, root
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| send update t1 set x= x + 10;
 | |
| --connection con2
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| send update t1 set x= x + 20;
 | |
| --connection con3
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| send update t1 set x= x + 30;
 | |
| --connection con4
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| send update t1 set x= x + 40;
 | |
| --connection con5
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| send update t1 set x= x + 50;
 | |
| --connection con6
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| send update t1 set x= x + 60;
 | |
| --connection con7
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| send update t1 set x= x + 70;
 | |
| --connection con8
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| update t1 set x= x + 80;
 | |
| --connection con1
 | |
| reap;
 | |
| --disconnect con1
 | |
| --connection con2
 | |
| reap;
 | |
| --disconnect con2
 | |
| --connection con3
 | |
| reap;
 | |
| --disconnect con3
 | |
| --connection con4
 | |
| reap;
 | |
| --disconnect con4
 | |
| --connection con5
 | |
| reap;
 | |
| --disconnect con5
 | |
| --connection con6
 | |
| reap;
 | |
| --disconnect con6
 | |
| --connection con7
 | |
| reap;
 | |
| --disconnect con7
 | |
| --disconnect con8
 | |
| --connection default
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| drop tables t1;
 | |
| set timestamp= default;
 | |
| 
 | |
| --echo # Concurrent DML (LIMIT)
 | |
| create or replace table t1 (x int) with system versioning engine heap
 | |
| partition by system_time limit 1 auto partitions 3;
 | |
| 
 | |
| insert into t1 values (1);
 | |
| 
 | |
| --let $max_loop= 3
 | |
| # For more intensity use
 | |
| # --let $max_loop= 30
 | |
| --echo update t1 set x= x + N; # (running multithreaded for $max_loop times)
 | |
| --disable_query_log
 | |
| --disable_result_log
 | |
| --connect con9, localhost, root
 | |
| --connect con10, localhost, root
 | |
| --connect con11, localhost, root
 | |
| --connect con12, localhost, root
 | |
| --connect con13, localhost, root
 | |
| --connect con14, localhost, root
 | |
| --connect con15, localhost, root
 | |
| --connect con16, localhost, root
 | |
| --connect con17, localhost, root
 | |
| --connect con18, localhost, root
 | |
| --connect con19, localhost, root
 | |
| --connect con20, localhost, root
 | |
| --connect con8, localhost, root
 | |
| --connect con7, localhost, root
 | |
| --connect con6, localhost, root
 | |
| --connect con5, localhost, root
 | |
| --connect con4, localhost, root
 | |
| --connect con3, localhost, root
 | |
| --connect con2, localhost, root
 | |
| --connect con1, localhost, root
 | |
| --let $i= 0
 | |
| while ($i < $max_loop)
 | |
| {
 | |
|   --connection con1
 | |
|   send update t1 set x= x + 100;
 | |
|   --connection con2
 | |
|   send update t1 set x= x + 200;
 | |
|   --connection con3
 | |
|   send update t1 set x= x + 300;
 | |
|   --connection con4
 | |
|   send update t1 set x= x + 400;
 | |
|   --connection con5
 | |
|   send update t1 set x= x + 500;
 | |
|   --connection con6
 | |
|   send update t1 set x= x + 600;
 | |
|   --connection con7
 | |
|   send update t1 set x= x + 700;
 | |
|   --connection con8
 | |
|   send update t1 set x= x + 800;
 | |
|   --connection con9
 | |
|   send update t1 set x= x + 900;
 | |
|   --connection con10
 | |
|   send update t1 set x= x + 1000;
 | |
|   --connection con11
 | |
|   send update t1 set x= x + 1100;
 | |
|   --connection con12
 | |
|   send update t1 set x= x + 1200;
 | |
|   --connection con13
 | |
|   send update t1 set x= x + 1300;
 | |
|   --connection con14
 | |
|   send update t1 set x= x + 1400;
 | |
|   --connection con15
 | |
|   send update t1 set x= x + 1500;
 | |
|   --connection con16
 | |
|   send update t1 set x= x + 1600;
 | |
|   --connection con17
 | |
|   send update t1 set x= x + 1700;
 | |
|   --connection con18
 | |
|   send update t1 set x= x + 1800;
 | |
|   --connection con19
 | |
|   send update t1 set x= x + 1900;
 | |
|   --connection con20
 | |
|   send update t1 set x= x + 2000;
 | |
|   --connection con1
 | |
|   reap;
 | |
|   --connection con2
 | |
|   reap;
 | |
|   --connection con3
 | |
|   reap;
 | |
|   --connection con4
 | |
|   reap;
 | |
|   --connection con5
 | |
|   reap;
 | |
|   --connection con6
 | |
|   reap;
 | |
|   --connection con7
 | |
|   reap;
 | |
|   --connection con8
 | |
|   reap;
 | |
|   --connection con9
 | |
|   reap;
 | |
|   --connection con10
 | |
|   reap;
 | |
|   --connection con11
 | |
|   reap;
 | |
|   --connection con12
 | |
|   reap;
 | |
|   --connection con13
 | |
|   reap;
 | |
|   --connection con14
 | |
|   reap;
 | |
|   --connection con15
 | |
|   reap;
 | |
|   --connection con16
 | |
|   reap;
 | |
|   --connection con17
 | |
|   reap;
 | |
|   --connection con18
 | |
|   reap;
 | |
|   --connection con19
 | |
|   reap;
 | |
|   --connection con20
 | |
|   reap;
 | |
|   --inc $i
 | |
| }
 | |
| 
 | |
| --disconnect con1
 | |
| --disconnect con2
 | |
| --disconnect con3
 | |
| --disconnect con4
 | |
| --disconnect con5
 | |
| --disconnect con6
 | |
| --disconnect con7
 | |
| --disconnect con8
 | |
| --disconnect con9
 | |
| --disconnect con10
 | |
| --disconnect con11
 | |
| --disconnect con12
 | |
| --disconnect con13
 | |
| --disconnect con14
 | |
| --disconnect con15
 | |
| --disconnect con16
 | |
| --disconnect con17
 | |
| --disconnect con18
 | |
| --disconnect con19
 | |
| --disconnect con20
 | |
| 
 | |
| --connection default
 | |
| # Result is undeterministic under LIMIT concurrency (MDEV-28459)
 | |
| # show create table t1;
 | |
| 
 | |
| --enable_query_log
 | |
| --enable_result_log
 | |
| 
 | |
| drop tables t1;
 | |
| 
 | |
| --echo # Transaction
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning engine innodb
 | |
| partition by system_time interval 1 hour auto;
 | |
| 
 | |
| insert into t1 values (1);
 | |
| set timestamp= unix_timestamp('2000-01-01 01:00:00');
 | |
| start transaction;
 | |
| update t1 set x= 0;
 | |
| --connect con1, localhost, root
 | |
| select * from t1;
 | |
| show create table t1;
 | |
| --connection default
 | |
| commit;
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| start transaction;
 | |
| update t1 set x= 1;
 | |
| --connection con1
 | |
| select * from t1;
 | |
| --connection default
 | |
| rollback;
 | |
| show create table t1;
 | |
| --disconnect con1
 | |
| --connection default
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-25479 Auto-create: 2nd and further executions of PS or SP fail to create partition
 | |
| --echo #
 | |
| create table t (a int) with system versioning
 | |
|   partition by system_time interval 1 hour auto;
 | |
| 
 | |
| insert into t values (1), (2);
 | |
| prepare stmt from "update t set a= a + 1";
 | |
| set @@timestamp= @@timestamp + 3601;
 | |
| execute stmt;
 | |
| set @@timestamp= @@timestamp + 3601;
 | |
| execute stmt;
 | |
| drop prepare stmt;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t;
 | |
| 
 | |
| create procedure sp() update t set a= a + 1;
 | |
| set @@timestamp= @@timestamp + 3601;
 | |
| call sp();
 | |
| set @@timestamp= @@timestamp + 3601;
 | |
| call sp();
 | |
| drop procedure sp;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t;
 | |
| 
 | |
| # Cleanup
 | |
| drop table t;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-23639 Auto-create does not work under LOCK TABLES or inside triggers
 | |
| --echo #
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create or replace table t1 (x int) with system versioning
 | |
| partition by system_time interval 1 hour auto
 | |
| partitions 3;
 | |
| 
 | |
| create table t2 (x int);
 | |
| create table t3 (x int);
 | |
| insert into t3 values (3);
 | |
| 
 | |
| create trigger tr after insert on t2 for each row update t1 set x= x + 11;
 | |
| create or replace procedure sp() update t1 set x= x + 5;
 | |
| create or replace procedure sp2() insert into t2 values (5);
 | |
| prepare ps from 'update t1 set x= x + 6';
 | |
| prepare ps2 from 'insert into t2 values (6)';
 | |
| 
 | |
| insert into t1 values (1);
 | |
| set timestamp= unix_timestamp('2000-01-01 02:00:00');
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| insert into t2 values (2);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 03:00:00');
 | |
| call sp; call sp;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| set timestamp= unix_timestamp('2000-01-01 04:00:00');
 | |
| call sp2; call sp2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 05:00:00');
 | |
| execute ps; execute ps;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| set timestamp= unix_timestamp('2000-01-01 06:00:00');
 | |
| execute ps2; execute ps2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 08:00:00');
 | |
| lock tables t1 write, t2 write;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| set timestamp= unix_timestamp('2000-01-01 09:00:00');
 | |
| update t1 set x= x + 1;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| set timestamp= unix_timestamp('2000-01-01 10:00:00');
 | |
| update t1 set x= x + 2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| update t2 set x= x + 1;
 | |
| set timestamp= unix_timestamp('2000-01-01 11:00:00');
 | |
| insert into t2 values (4);
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| --error ER_TABLE_NOT_LOCKED
 | |
| update t3 set x= x + 1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 12:00:00');
 | |
| call sp; call sp;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| set timestamp= unix_timestamp('2000-01-01 13:00:00');
 | |
| call sp2; call sp2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| set timestamp= unix_timestamp('2000-01-01 14:00:00');
 | |
| execute ps; execute ps;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| set timestamp= unix_timestamp('2000-01-01 15:00:00');
 | |
| execute ps2; execute ps2;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| unlock tables;
 | |
| --replace_result $default_engine DEFAULT_ENGINE
 | |
| show create table t1;
 | |
| 
 | |
| # Cleanup
 | |
| drop tables t1, t2, t3;
 | |
| drop procedure sp;
 | |
| drop procedure sp2;
 | |
| drop prepare ps;
 | |
| drop prepare ps2;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-27456 Assertion `!thd->is_error()' fails in vers_create_partitions upon DML with ER_UNKNOWN_PARTITION
 | |
| --echo #
 | |
| create table t (a int) with system versioning
 | |
| partition by system_time interval 1 minute auto;
 | |
| set @@timestamp= @@timestamp + 61;
 | |
| select * from t;
 | |
| --error ER_UNKNOWN_PARTITION
 | |
| delete from t partition (px);
 | |
| lock tables t write;
 | |
| --error ER_UNKNOWN_PARTITION
 | |
| delete from t partition (px);
 | |
| unlock tables;
 | |
| drop table t;
 | |
| set timestamp= default;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-28978 Assertion failure in THD::binlog_query or unexpected
 | |
| --echo #            ER_ERROR_ON_WRITE with auto-partitioning
 | |
| --echo #
 | |
| create table t (a int) with system versioning partition by system_time limit 6 auto;
 | |
| insert into t () values (),(),(),(),(),();
 | |
| update t set a = 1;
 | |
| update t set a = 2 limit 0;
 | |
| # cleanup
 | |
| drop table t;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-31244 Assertion "not SELECT" in vers_set_hist_part()
 | |
| --echo #
 | |
| create table t (a int) with system versioning partition by system_time;
 | |
| --delimiter $
 | |
| create function f() returns int
 | |
| begin
 | |
|   update t set a = 1;
 | |
|   return 1;
 | |
| end $
 | |
| --delimiter ;
 | |
| create procedure p() select f();
 | |
| call p();
 | |
| call p();
 | |
| # cleanup
 | |
| drop procedure p;
 | |
| drop function f;
 | |
| drop table t;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-29873 MSAN uninitialized value errors in bcmp /
 | |
| --echo #            prep_alter_part_table upon re-partitioning by system time
 | |
| --echo #
 | |
| create table t (a int) with system versioning partition by system_time interval 5 week;
 | |
| alter table t partition by system_time interval 10 week;
 | |
| # cleanup
 | |
| drop table t;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-16546 System versioning setting to allow history modification
 | |
| --echo #
 | |
| create table t1 (a varchar(100)) with system versioning
 | |
| partition by system_time interval 1 day
 | |
| starts '2021-09-30 00:00:00' partitions 3;
 | |
| set system_versioning_insert_history=1;
 | |
| --replace_result $sys_time_max SYS_TIME_MAX
 | |
| eval insert into t1 (a,row_start,row_end) values
 | |
| ('p0',                   '2021-09-30', '2021-09-30 10:00:00'),
 | |
| ('p1',                   '2021-09-30', '2021-10-01 10:00:00'),
 | |
| ('overflows, so also p1','2021-09-30', '2021-10-10 10:00:00'),
 | |
| ('pn, current',          '2021-09-30', $sys_time_max);
 | |
| select table_name,partition_name,partition_ordinal_position,partition_method,partition_description,table_rows
 | |
| from information_schema.partitions where table_schema='test';
 | |
| drop table t1;
 | |
| set system_versioning_insert_history=0;
 | |
| 
 | |
| --disable_prepare_warnings
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-29727 ALTER and CREATE with default partitioning
 | |
| --echo #            differently react to SQL_MODE => unusable SHOW CREATE
 | |
| --echo #
 | |
| create table t (a int) with system versioning;
 | |
| --error WARN_VERS_PARAMETERS
 | |
| alter table t partition by system_time partitions 3;
 | |
| drop table t;
 | |
| --error WARN_VERS_PARAMETERS
 | |
| create table t (a int) with system versioning partition by system_time partitions 3;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-36115 InnoDB: assertion: node->pcur->rel_pos == BTR_PCUR_ON
 | |
| --echo #            in row_update_for_mysql
 | |
| --echo #
 | |
| create table t (a int key) engine=innodb
 | |
| with system versioning
 | |
| partition by key() partitions 3;
 | |
| 
 | |
| start transaction;
 | |
| insert into t values (1),(2),(3),(4),(5),(6),(7),(8);
 | |
| set timestamp=+1;
 | |
| delete from t;
 | |
| insert into t values (1),(2);
 | |
| DELETE from t;
 | |
| drop table t;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-36817 Server crashes in do_mark_index_columns instead of
 | |
| --echo #            ER_DUP_ENTRY on partitioned table
 | |
| --echo #
 | |
| create table t (f int, unique(f)) engine=innodb partition by key (f) partitions 2;
 | |
| insert into t (f) values (1), (3);
 | |
| --error ER_DUP_ENTRY
 | |
| update t set f = 0;
 | |
| drop table t;
 | |
| 
 | |
| --echo #
 | |
| --echo # End of 10.5 tests
 | |
| --echo #
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-31903 Server crashes in _ma_reset_history upon UNLOCK table with auto-create history partitions
 | |
| --echo #
 | |
| set timestamp= unix_timestamp('2000-01-01 00:00:00');
 | |
| create table t1 (x int) engine=aria with system versioning partition by system_time interval 1 hour auto partitions 3;
 | |
| insert into t1 values (1);
 | |
| 
 | |
| create table t2 (x int) engine=aria;
 | |
| create trigger tr after insert on t2 for each row update t1 set x= x + 11;
 | |
| lock tables t1 write, t2 write;
 | |
| update t1 set x= x + 1;
 | |
| set timestamp= unix_timestamp('2000-01-01 13:00:00');
 | |
| insert into t2 values (5);
 | |
| unlock tables;
 | |
| drop table t1, t2;
 | |
| set timestamp= default;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-29872 MSAN/Valgrind uninitialised value errors in TABLE::vers_switch_partition
 | |
| --echo #
 | |
| create table t (a int) with system versioning partition by system_time limit 100 partitions 3;
 | |
| let $emb= `select if(version() like '%embedded%', 1, 0)`;
 | |
| if (!$emb)
 | |
| {
 | |
|   --disable_result_log
 | |
|   --disable_query_log
 | |
|   --error ER_DELAYED_NOT_SUPPORTED
 | |
|   insert delayed into t () values ();
 | |
|   --enable_query_log
 | |
|   --enable_result_log
 | |
| }
 | |
| # cleanup
 | |
| drop table t;
 | |
| 
 | |
| --echo #
 | |
| --echo # End of 10.9 tests
 | |
| --echo #
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-34775 Wrong reopen of already open routine due to auto-create in SP
 | |
| --echo #
 | |
| 
 | |
| create table t (a int) with system versioning
 | |
| partition by system_time
 | |
| interval 1 minute auto;
 | |
| 
 | |
| --delimiter $
 | |
| create function f()
 | |
| returns int
 | |
| begin
 | |
|   replace into t select * from t;
 | |
|   return 0;
 | |
| end $
 | |
| --delimiter ;
 | |
| 
 | |
| set timestamp= @@timestamp + 61;
 | |
| select f();
 | |
| 
 | |
| drop table t;
 | |
| drop function f;
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-33370 Assertion `!is_set() || (m_status == DA_OK_BULK &&
 | |
| --echo #            is_bulk_op())' failed after ALTER TABLE of versioned table
 | |
| --echo #
 | |
| create table t1 (i int) with system versioning
 | |
| partition by system_time interval 1 month (
 | |
|     partition ver_p1 history,
 | |
|     partition ver_p2 history,
 | |
|     partition ver_pn current);
 | |
| 
 | |
| --error ER_DATA_OUT_OF_RANGE
 | |
| alter table `t1` partition by system_time interval 10007 year ;
 | |
| drop table t1;
 | |
| 
 | |
| --echo #
 | |
| --echo # End of 10.11 tests
 | |
| --echo #
 | |
| 
 | |
| set global innodb_stats_persistent= @save_persistent;
 | |
| --source suite/versioning/common_finish.inc
 | 
