mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-04 04:46:15 +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;
 |