mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 08:28:13 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			71 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| #
 | |
| # Partition pruning tests for new COLUMN LIST feature
 | |
| #
 | |
| -- source include/have_partition.inc
 | |
| 
 | |
| --disable_warnings
 | |
| drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
 | |
| --enable_warnings
 | |
| 
 | |
| create table t1 (a char, b char, c char)
 | |
| partition by range columns(a,b,c)
 | |
| ( partition p0 values less than ('a','b','c'));
 | |
| insert into t1 values ('a', NULL, 'd');
 | |
| explain partitions select * from t1 where a = 'a' AND c = 'd';
 | |
| select * from t1 where a = 'a' AND c = 'd';
 | |
| drop table t1;
 | |
| 
 | |
| ## COLUMN_LIST partition pruning tests
 | |
| create table t1 (a int not null) partition by range columns(a) (
 | |
|   partition p0 values less than (10),
 | |
|   partition p1 values less than (20),
 | |
|   partition p2 values less than (30),
 | |
|   partition p3 values less than (40),
 | |
|   partition p4 values less than (50),
 | |
|   partition p5 values less than (60),
 | |
|   partition p6 values less than (70)
 | |
| );
 | |
| insert into t1 values (5),(15),(25),(35),(45),(55),(65);
 | |
| insert into t1 values (5),(15),(25),(35),(45),(55),(65);
 | |
| 
 | |
| create table t2 (a int not null) partition by range(a) (
 | |
|   partition p0 values less than (10),
 | |
|   partition p1 values less than (20),
 | |
|   partition p2 values less than (30),
 | |
|   partition p3 values less than (40),
 | |
|   partition p4 values less than (50),
 | |
|   partition p5 values less than (60),
 | |
|   partition p6 values less than (70)
 | |
| );
 | |
| insert into t2 values (5),(15),(25),(35),(45),(55),(65);
 | |
| insert into t2 values (5),(15),(25),(35),(45),(55),(65);
 | |
| 
 | |
| explain partitions select * from t1 where a > 35 and a < 45;
 | |
| explain partitions select * from t2 where a > 35 and a < 45;
 | |
| 
 | |
| drop table t1, t2;
 | |
| 
 | |
| create table t1 (a int not null, b int not null ) 
 | |
| partition by range columns(a,b) (
 | |
|   partition p01 values less than (2,10),
 | |
|   partition p02 values less than (2,20),
 | |
|   partition p03 values less than (2,30),
 | |
| 
 | |
|   partition p11 values less than (4,10),
 | |
|   partition p12 values less than (4,20),
 | |
|   partition p13 values less than (4,30),
 | |
| 
 | |
|   partition p21 values less than (6,10),
 | |
|   partition p22 values less than (6,20),
 | |
|   partition p23 values less than (6,30)
 | |
| );
 | |
| 
 | |
| insert into t1 values (2,5), (2,15), (2,25),
 | |
|   (4,5), (4,15), (4,25), (6,5), (6,15), (6,25);
 | |
| insert into t1 select * from t1;
 | |
| 
 | |
| explain partitions select * from t1 where a=2;
 | |
| explain partitions select * from t1 where a=4;
 | |
| explain partitions select * from t1 where a=2 and b < 22;
 | |
| 
 | |
| drop table t1;
 | 
