mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 15:50:51 +03:00 
			
		
		
		
	moved all partition create table error tests to one test for easier maintenance
This commit is contained in:
		| @@ -87,269 +87,3 @@ partition by list (b*a) | ||||
| partition x2 values in (3, 11, 5, 7) tablespace ts2, | ||||
| partition x3 values in (16, 8, 5+19, 70-43) tablespace ts3); | ||||
| drop table t1; | ||||
| partition by list (a) | ||||
| partitions 3 | ||||
| (partition x1 values in (1,2,9,4) tablespace ts1, | ||||
| partition x2 values in (3, 11, 5, 7) tablespace ts2, | ||||
| partition x3 values in (16, 8, 5+19, 70-43) tablespace ts3); | ||||
| ERROR 42000: Partitioning can not be used stand-alone in query near 'partition by list (a) | ||||
| partitions 3 | ||||
| (partition x1 values in (1,2,9,4) tablespace ' at line 1 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2; | ||||
| ERROR HY000: For LIST partitions each partition must be defined | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (sin(a)) | ||||
| partitions 3 | ||||
| (partition x1 values in (1,2,9,4) tablespace ts1, | ||||
| partition x2 values in (3, 11, 5, 7) tablespace ts2, | ||||
| partition x3 values in (16, 8, 5+19, 70-43) tablespace ts3); | ||||
| ERROR HY000: The PARTITION function returns the wrong type | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by key (a+2) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '+2) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| part' at line 6 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by key (a) | ||||
| partitions 3 | ||||
| (partition tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3)' at line 8 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by key (a,d) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR HY000: Field in list of fields for partition function not found in table | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (a + d) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR 42S22: Unknown column 'd' in 'partition function' | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (sin(a)) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR HY000: The PARTITION function returns the wrong type | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by key (a) | ||||
| partitions 3 | ||||
| (partition x1, partition x2); | ||||
| ERROR 42000: Wrong number of partitions defined, mismatch with previous setting near ')' at line 8 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (rand(a)) | ||||
| partitions 2 | ||||
| (partition x1, partition x2); | ||||
| ERROR 42000: Constant/Random expression in (sub)partitioning function is not allowed near ') | ||||
| partitions 2 | ||||
| (partition x1, partition x2)' at line 6 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (rand(a)) | ||||
| partitions 2 | ||||
| (partition x1 values less than (0), partition x2 values less than (2)); | ||||
| ERROR 42000: Constant/Random expression in (sub)partitioning function is not allowed near ') | ||||
| partitions 2 | ||||
| (partition x1 values less than (0), partition x2 values less than' at line 6 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (rand(a)) | ||||
| partitions 2 | ||||
| (partition x1 values in (1), partition x2 values in (2)); | ||||
| ERROR 42000: Constant/Random expression in (sub)partitioning function is not allowed near ') | ||||
| partitions 2 | ||||
| (partition x1 values in (1), partition x2 values in (2))' at line 6 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4), | ||||
| partition x2 values less than (5)); | ||||
| ERROR HY000: Only RANGE PARTITIONING can use VALUES LESS THAN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4), | ||||
| partition x2 values in (5)); | ||||
| ERROR HY000: Only LIST PARTITIONING can use VALUES IN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4,6), | ||||
| partition x2 values in (5,7)); | ||||
| ERROR HY000: Only LIST PARTITIONING can use VALUES IN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by key (b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by key (a, b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (a+b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by key (b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by key (a, b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (a+b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (rand(a+b)); | ||||
| ERROR 42000: Constant/Random expression in (sub)partitioning function is not allowed near ')' at line 7 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (sin(a+b)) | ||||
| (partition x1 (subpartition x11, subpartition x12), | ||||
| partition x2 (subpartition x21, subpartition x22)); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by range (a) | ||||
| subpartition by key (a+b) | ||||
| (partition x1 values less than (1) (subpartition x11, subpartition x12), | ||||
| partition x2 values less than (2) (subpartition x21, subpartition x22)); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '+b) | ||||
| (partition x1 values less than (1) (subpartition x11, subpartition x12), | ||||
| par' at line 7 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by range (a) | ||||
| subpartition by key (a,d) | ||||
| (partition x1 values less than (1) (subpartition x11, subpartition x12), | ||||
| partition x2 values less than (2) (subpartition x21, subpartition x22)); | ||||
| ERROR HY000: Field in list of fields for partition function not found in table | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (3+4); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by range (a) | ||||
| subpartition by hash (a+d) | ||||
| (partition x1 values less than (1) (subpartition x11, subpartition x12), | ||||
| partition x2 values less than (2) (subpartition x21, subpartition x22)); | ||||
| ERROR 42S22: Unknown column 'd' in 'partition function' | ||||
|   | ||||
							
								
								
									
										544
									
								
								mysql-test/r/partition_error.result
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										544
									
								
								mysql-test/r/partition_error.result
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,544 @@ | ||||
| partition by list (a) | ||||
| partitions 3 | ||||
| (partition x1 values in (1,2,9,4) tablespace ts1, | ||||
| partition x2 values in (3, 11, 5, 7) tablespace ts2, | ||||
| partition x3 values in (16, 8, 5+19, 70-43) tablespace ts3); | ||||
| ERROR 42000: Partitioning can not be used stand-alone in query near 'partition by list (a) | ||||
| partitions 3 | ||||
| (partition x1 values in (1,2,9,4) tablespace ' at line 1 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2; | ||||
| ERROR HY000: For LIST partitions each partition must be defined | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (sin(a)) | ||||
| partitions 3 | ||||
| (partition x1 values in (1,2,9,4) tablespace ts1, | ||||
| partition x2 values in (3, 11, 5, 7) tablespace ts2, | ||||
| partition x3 values in (16, 8, 5+19, 70-43) tablespace ts3); | ||||
| ERROR HY000: The PARTITION function returns the wrong type | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by key (a+2) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '+2) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| part' at line 6 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by key (a) | ||||
| partitions 3 | ||||
| (partition tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3)' at line 8 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by key (a,d) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR HY000: Field in list of fields for partition function not found in table | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (a + d) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR 42S22: Unknown column 'd' in 'partition function' | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (sin(a)) | ||||
| partitions 3 | ||||
| (partition x1 tablespace ts1, | ||||
| partition x2 tablespace ts2, | ||||
| partition x3 tablespace ts3); | ||||
| ERROR HY000: The PARTITION function returns the wrong type | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by key (a) | ||||
| partitions 3 | ||||
| (partition x1, partition x2); | ||||
| ERROR 42000: Wrong number of partitions defined, mismatch with previous setting near ')' at line 8 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (rand(a)) | ||||
| partitions 2 | ||||
| (partition x1, partition x2); | ||||
| ERROR 42000: Constant/Random expression in (sub)partitioning function is not allowed near ') | ||||
| partitions 2 | ||||
| (partition x1, partition x2)' at line 6 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (rand(a)) | ||||
| partitions 2 | ||||
| (partition x1 values less than (0), partition x2 values less than (2)); | ||||
| ERROR 42000: Constant/Random expression in (sub)partitioning function is not allowed near ') | ||||
| partitions 2 | ||||
| (partition x1 values less than (0), partition x2 values less than' at line 6 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (rand(a)) | ||||
| partitions 2 | ||||
| (partition x1 values in (1), partition x2 values in (2)); | ||||
| ERROR 42000: Constant/Random expression in (sub)partitioning function is not allowed near ') | ||||
| partitions 2 | ||||
| (partition x1 values in (1), partition x2 values in (2))' at line 6 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4), | ||||
| partition x2 values less than (5)); | ||||
| ERROR HY000: Only RANGE PARTITIONING can use VALUES LESS THAN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4), | ||||
| partition x2 values in (5)); | ||||
| ERROR HY000: Only LIST PARTITIONING can use VALUES IN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by hash (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4,6), | ||||
| partition x2 values in (5,7)); | ||||
| ERROR HY000: Only LIST PARTITIONING can use VALUES IN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by key (b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by key (a, b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (a+b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by key (b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by key (a, b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (a+b); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (rand(a+b)); | ||||
| ERROR 42000: Constant/Random expression in (sub)partitioning function is not allowed near ')' at line 7 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (sin(a+b)) | ||||
| (partition x1 (subpartition x11, subpartition x12), | ||||
| partition x2 (subpartition x21, subpartition x22)); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by range (a) | ||||
| subpartition by key (a+b) | ||||
| (partition x1 values less than (1) (subpartition x11, subpartition x12), | ||||
| partition x2 values less than (2) (subpartition x21, subpartition x22)); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '+b) | ||||
| (partition x1 values less than (1) (subpartition x11, subpartition x12), | ||||
| par' at line 7 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by range (a) | ||||
| subpartition by key (a,d) | ||||
| (partition x1 values less than (1) (subpartition x11, subpartition x12), | ||||
| partition x2 values less than (2) (subpartition x21, subpartition x22)); | ||||
| ERROR HY000: Field in list of fields for partition function not found in table | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by hash (3+4); | ||||
| ERROR HY000: It is only possible to mix RANGE/LIST partitioning with HASH/KEY partitioning for subpartitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by range (a) | ||||
| subpartition by hash (a+d) | ||||
| (partition x1 values less than (1) (subpartition x11, subpartition x12), | ||||
| partition x2 values less than (2) (subpartition x21, subpartition x22)); | ||||
| ERROR 42S22: Unknown column 'd' in 'partition function' | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a); | ||||
| ERROR HY000: For RANGE partitions each partition must be defined | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a+d) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4) tablespace ts1, | ||||
| partition x2 values less than (8) tablespace ts2); | ||||
| ERROR 42S22: Unknown column 'd' in 'partition function' | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4.0) tablespace ts1, | ||||
| partition x2 values less than (8) tablespace ts2); | ||||
| ERROR HY000: VALUES LESS THAN value must be of same type as partition function | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (3+4) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4) tablespace ts1, | ||||
| partition x2 values less than (8) tablespace ts2); | ||||
| ERROR HY000: Constant/Random expression in (sub)partitioning function is not allowed | ||||
| CREATE TABLE t1 (  | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4), | ||||
| partition x2); | ||||
| ERROR HY000: RANGE PARTITIONING requires definition of VALUES LESS THAN for each partition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4), | ||||
| partition x2); | ||||
| ERROR HY000: Only LIST PARTITIONING can use VALUES IN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4), | ||||
| partition x2 values less than (5)); | ||||
| ERROR HY000: Only LIST PARTITIONING can use VALUES IN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than 4, | ||||
| partition x2 values less than (5)); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '4, | ||||
| partition x2 values less than (5))' at line 8 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than maxvalue, | ||||
| partition x2 values less than (5)); | ||||
| ERROR 42000: MAXVALUE can only be used in last partition definition near '))' at line 9 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than maxvalue, | ||||
| partition x2 values less than maxvalue); | ||||
| ERROR 42000: MAXVALUE can only be used in last partition definition near 'maxvalue)' at line 9 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4), | ||||
| partition x2 values less than (3)); | ||||
| ERROR HY000: VALUES LESS THAN value must be strictly increasing for each partition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (sin(a)) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4), | ||||
| partition x2 values less than (5)); | ||||
| ERROR HY000: The PARTITION function returns the wrong type | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by list (a) | ||||
| subpartition by hash (a+b) | ||||
| subpartitions 3 | ||||
| ( partition x1 values in (1,2,4) | ||||
| ( subpartition x11 nodegroup 0, | ||||
| subpartition x12 nodegroup 1), | ||||
| partition x2 values in (3,5,6) | ||||
| ( subpartition x21 nodegroup 0, | ||||
| subpartition x22 nodegroup 1) | ||||
| ); | ||||
| ERROR 42000: Wrong number of subpartitions defined, mismatch with previous setting near '), | ||||
| partition x2 values in (3,5,6) | ||||
| ( subpartition x21 nodegroup 0, | ||||
| subpartition x' at line 11 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by list (a) | ||||
| subpartition by hash (a+b) | ||||
| ( partition x1 values in (1) | ||||
| ( subpartition x11 nodegroup 0, | ||||
| subpartition xextra, | ||||
| subpartition x12 nodegroup 1), | ||||
| partition x2 values in (2) | ||||
| ( subpartition x21 nodegroup 0, | ||||
| subpartition x22 nodegroup 1) | ||||
| ); | ||||
| ERROR 42000: Wrong number of subpartitions defined, mismatch with previous setting near ') | ||||
| )' at line 14 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a)  | ||||
| subpartition by list (a+b) | ||||
| ( partition x1 | ||||
| ( subpartition x11 engine myisam, | ||||
| subpartition x12 engine myisam), | ||||
| partition x2  | ||||
| ( subpartition x21 engine myisam, | ||||
| subpartition x22 engine myisam) | ||||
| ); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'list (a+b) | ||||
| ( partition x1 | ||||
| ( subpartition x11 engine myisam, | ||||
| subpartition x12 eng' at line 7 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by list (a+b) | ||||
| ( partition x1 | ||||
| ( subpartition x11 engine myisam values in (0), | ||||
| subpartition x12 engine myisam values in (1)), | ||||
| partition x2 | ||||
| ( subpartition x21 engine myisam values in (0), | ||||
| subpartition x22 engine myisam values in (1)) | ||||
| ); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'list (a+b) | ||||
| ( partition x1 | ||||
| ( subpartition x11 engine myisam values in (0), | ||||
| subpar' at line 7 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a); | ||||
| ERROR HY000: For LIST partitions each partition must be defined | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (3+4) | ||||
| partitions 2  | ||||
| (partition x1 values in (4) tablespace ts1, | ||||
| partition x2 values in (8) tablespace ts2); | ||||
| ERROR HY000: Constant/Random expression in (sub)partitioning function is not allowed | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a+d) | ||||
| partitions 2 | ||||
| (partition x1 values in (4) tablespace ts1, | ||||
| partition x2 values in (8) tablespace ts2); | ||||
| ERROR 42S22: Unknown column 'd' in 'partition function' | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4), | ||||
| partition x2); | ||||
| ERROR HY000: LIST PARTITIONING requires definition of VALUES IN for each partition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4), | ||||
| partition x2 values less than (5)); | ||||
| ERROR HY000: Only RANGE PARTITIONING can use VALUES LESS THAN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4,6), | ||||
| partition x2); | ||||
| ERROR HY000: LIST PARTITIONING requires definition of VALUES IN for each partition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4, 12+9), | ||||
| partition x2 values in (3, 21)); | ||||
| ERROR HY000: Multiple definition of same constant in list partitioning | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4.0, 12+8), | ||||
| partition x2 values in (3, 21)); | ||||
| ERROR HY000: VALUES IN value must be of same type as partition function | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2 | ||||
| (partition x1 values in 4, | ||||
| partition x2 values in (5)); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '4, | ||||
| partition x2 values in (5))' at line 8 | ||||
| @@ -108,124 +108,6 @@ CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a); | ||||
| ERROR HY000: For RANGE partitions each partition must be defined | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a+d) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4) tablespace ts1, | ||||
| partition x2 values less than (8) tablespace ts2); | ||||
| ERROR 42S22: Unknown column 'd' in 'partition function' | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4.0) tablespace ts1, | ||||
| partition x2 values less than (8) tablespace ts2); | ||||
| ERROR HY000: VALUES LESS THAN value must be of same type as partition function | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (3+4) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4) tablespace ts1, | ||||
| partition x2 values less than (8) tablespace ts2); | ||||
| ERROR HY000: Constant/Random expression in (sub)partitioning function is not allowed | ||||
| CREATE TABLE t1 (  | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4), | ||||
| partition x2); | ||||
| ERROR HY000: RANGE PARTITIONING requires definition of VALUES LESS THAN for each partition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4), | ||||
| partition x2); | ||||
| ERROR HY000: Only LIST PARTITIONING can use VALUES IN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values in (4), | ||||
| partition x2 values less than (5)); | ||||
| ERROR HY000: Only LIST PARTITIONING can use VALUES IN in partition definition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by list (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than 4, | ||||
| partition x2 values less than (5)); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '4, | ||||
| partition x2 values less than (5))' at line 8 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than maxvalue, | ||||
| partition x2 values less than (5)); | ||||
| ERROR 42000: MAXVALUE can only be used in last partition definition near '))' at line 9 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than maxvalue, | ||||
| partition x2 values less than maxvalue); | ||||
| ERROR 42000: MAXVALUE can only be used in last partition definition near 'maxvalue)' at line 9 | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (a) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4), | ||||
| partition x2 values less than (3)); | ||||
| ERROR HY000: VALUES LESS THAN value must be strictly increasing for each partition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key(a,b)) | ||||
| partition by range (sin(a)) | ||||
| partitions 2 | ||||
| (partition x1 values less than (4), | ||||
| partition x2 values less than (5)); | ||||
| ERROR HY000: The PARTITION function returns the wrong type | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b))  | ||||
| partition by range (a) | ||||
| subpartition by hash (a+b)  | ||||
| @@ -421,35 +303,3 @@ a	b	c | ||||
| 1	1	1 | ||||
| 4	1	1 | ||||
| drop table t1; | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by range (a+b) | ||||
| subpartition by key (a) | ||||
| ( partition x1 | ||||
| ( subpartition x11 engine myisam, | ||||
| subpartition x12 engine myisam), | ||||
| partition x2 | ||||
| ( subpartition x21 engine myisam, | ||||
| subpartition x22 engine myisam) | ||||
| ); | ||||
| ERROR HY000: RANGE PARTITIONING requires definition of VALUES LESS THAN for each partition | ||||
| CREATE TABLE t1 ( | ||||
| a int not null, | ||||
| b int not null, | ||||
| c int not null, | ||||
| primary key (a,b)) | ||||
| partition by key (a) | ||||
| subpartition by range (a+b) | ||||
| ( partition x1 | ||||
| ( subpartition x11 engine myisam values less than (0), | ||||
| subpartition x12 engine myisam values less than (1)), | ||||
| partition x2 | ||||
| ( subpartition x21 engine myisam values less than (0), | ||||
| subpartition x22 engine myisam values less than (1)) | ||||
| ); | ||||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'range (a+b) | ||||
| ( partition x1 | ||||
| ( subpartition x11 engine myisam values less than (0)' at line 7 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 tulin@dl145b.mysql.com
					tulin@dl145b.mysql.com