213 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
			
		
		
	
	
			213 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
| #select c1 from t1 where c1 between 10000 and 1000;
 | |
| #select c1 from t1 where c1 not in (500, 1000)
 | |
| #select c1 from t1 where (c1, c2) = (2000, 10000);
 | |
| #select c1 from t1 where c1 = (select c2 from t1 where c2 >= 10000);
 | |
| #select c1 from t1 where c1 = 1000;
 | |
| select 0.2 HALF_OPEN_RANGE_SEL.
 | |
| select c1 from t1 where c1 > 1000 or (c1 > 2000 and c1 < 3000);
 | |
| # const
 | |
| select 1;
 | |
| select c1 from t1 where 1;
 | |
| select 1;
 | |
| select c1 from t1 where 1 > 0;
 | |
| select 0;
 | |
| select c1 from t1 where 0;
 | |
| select 0;
 | |
| select c1 from t1 where null;
 | |
| # distinct(1000), min(500), max(10000), nullnum(100)
 | |
| #equal a = 1
 | |
| select 1/500*0.99;
 | |
| select c1 from t1 where c1 = 999;
 | |
| select 1/500*0.99;
 | |
| select c1 from t1 where c1 = 10001;
 | |
| select 1/500*0.99;
 | |
| select c1 from t1 where c1 = 1000;
 | |
| select 0.01
 | |
| select c1 from t1 where c1 <=> null;
 | |
| select 0
 | |
| select c1 from t1 where c1 = null;
 | |
| select 1/500*0.99;
 | |
| select c1 from t1 where c1 + 1 = 1000;
 | |
| select 1/500*0.99;
 | |
| select c1 from t1 where c1 * 2 = 1000;
 | |
| select 0.005(DEFAULT_EQ_SEL)
 | |
| select c1 from t1 where c1 / 2 = 1000;
 | |
| select 1/500*0.99;
 | |
| select c1 from t1 where c1 - 100 = 1000;
 | |
| # range cond
 | |
| select 0;
 | |
| select c1 from t1 where c1 > null;
 | |
| select 1;
 | |
| select c1 from t1 where c1 > null or 1 > 0;
 | |
| select 0;
 | |
| select c1 from t1 where c1 > null or 1 > 2;
 | |
| select 0;
 | |
| select c1 from t1 where c1 < null;
 | |
| select 0.2 HALF_OPEN_RANGE_SEL.
 | |
| select c1 from t1 where c1 > 30;
 | |
| select 0.2 HALF_OPEN_RANGE_SEL.
 | |
| select c1 from t1 where c1 < 50;
 | |
| select 1.0/3.0 as not calc
 | |
| select c1 from t1 where c1 + 1 > 5;
 | |
| select 0.2 HALF_OPEN_RANGE_SEL.
 | |
| select c1 from t1 where c1 > 2000;
 | |
| select 0.2 HALF_OPEN_RANGE_SEL.
 | |
| select c1 from t1 where c1 >= 2000;
 | |
| select 0.2 HALF_OPEN_RANGE_SEL.
 | |
| select c1 from t1 where c1 < 5000;
 | |
| select (5000-1000)/(10000-1000) * 0.95;
 | |
| select c1 from t1 where c1 <= 5000;
 | |
| select 0.2 HALF_OPEN_RANGE_SEL.
 | |
| select c1 from t1 where c1 <= 500;
 | |
| select 0.2 HALF_OPEN_RANGE_SEL.
 | |
| select c1 from t1 where c1 >= 10000;
 | |
| select 1 - 0.01 - 1/500*0.99
 | |
| select c1 from t1 where c1 != 500;
 | |
| select 1 - 0.01 - 1/500*0.99
 | |
| select c1 from t1 where c1 != 50;
 | |
| select 1 - 0.01 - 1/500*0.99
 | |
| select c1 from t1 where c1 + 1 != 50;
 | |
| select 1 - 0.01 - 1/500*0.99
 | |
| select c1 from t1 where c1 * 2 != 50;
 | |
| select 0.5
 | |
| select c1 from t1 where c1 / 2 != 50;
 | |
| select 5 * 1 / 500 * 0.99 (5 * EST_DEF_VAR_EQ_SEL)
 | |
| select c1 from t1 where c1 > 2000 and c1 < 3000;
 | |
| select 0.2 HALF_OPEN_RANGE_SEL.
 | |
| select c1 from t1 where c1 > 10000 and c1 > 500;
 | |
| select 5 * 1 / 500 * 0.99 (5 * EST_DEF_VAR_EQ_SEL)
 | |
| select c1 from t1 where c1 < 10000 and c1 > 500;
 | |
| select 0.2 * 2
 | |
| select c1 from t1 where c1 < 500 or c1 > 10000;
 | |
| select 0.2 * 2
 | |
| select c1 from t1 where c1 > 2000 or c1 < 1000;
 | |
| select 0.2 * 2
 | |
| select c1 from t1 where c1 > 2000 or c1 < 1000 or c1 < 500;
 | |
| select 0.2 + 0.0099
 | |
| select c1 from t1 where c1 > 2000 or (c1 < 1000 and c1 > 500);
 | |
| select 5 * 1 / 500 * 0.99 (5 * EST_DEF_VAR_EQ_SEL)
 | |
| select c1 from t1 where c1 < 1000 and c1 > 500;
 | |
| select 0.2
 | |
| select c1 from t1 where c1 < 1000 or (c1 > 9000 and c1 > 2000 and c1 < 8000);
 | |
| select 0.2
 | |
| select c1 from t1 where c1 < 500 or (c1 > 10000 and c1 > 10001 and c1 < 499);
 | |
| #T_OP_IS
 | |
| select 0.01
 | |
| select c1 from t1 where c1 is null;
 | |
| select 1/500 * 0.99;
 | |
| select c1 from t1 where c1 is false;
 | |
| select 1- 0.01 - 1/500*0.99(suppose the ratio of false);
 | |
| select c1 from t1 where c1 is true;
 | |
| #T_OP_NOT
 | |
| select 1 - 0.01;
 | |
| select c1 from t1 where c1 is not null;
 | |
| select 1 - 1/500 * 0.99;
 | |
| select c1 from t1 where c1 is not false;
 | |
| select 0.01 + 1/500*0.99;
 | |
| select c1 from t1 where c1 is not true;
 | |
| select 0;
 | |
| select * from t1 where not 1;
 | |
| select 1;
 | |
| select * from t1 where not 0;
 | |
| select 0.2;
 | |
| select * from t1 where not c1 > 2000;
 | |
| select 0.2 + 0.2;
 | |
| select * from t1 where not (c1 > 2000 and c1 < 3000);
 | |
| select 0.99 - 1/500*0.99*2;
 | |
| select * from t1 where not c1 in (2000, 3000);
 | |
| #T_OP_IN
 | |
| select 1/500*0.99 * 3;
 | |
| select c1 from t1 where c1 in (500, 8000, 10000);
 | |
| select square(1/500*0.99) * 2
 | |
| select c1 from t1 where (c1,c2) in ((500, 8000), (8000, 10000));
 | |
| # const in const
 | |
| select 1;
 | |
| select c1 from t1 where (200) in (100, 200);
 | |
| select 1;
 | |
| select c1 from t1 where (200) in (100, 300, 400, 200);
 | |
| select 0;
 | |
| select c1 from t1 where (200) in (100, 300, 400, 500);
 | |
| select 1;
 | |
| select c1 from t1 where (200) in (c1, 300, 400, 500);
 | |
| select 1;
 | |
| select c1 from t1 where (c1) in (c1, 300, 400, 500);
 | |
| EXPECTED select 0.99 - 1/500*0.99 * 3;
 | |
| select c1 from t1 where c1 not in (500, 8000, 10000);
 | |
| EXPECTED select 0.99 - 1/500*0.99 * 2;
 | |
| select c1 from t1 where c1 not in (500, 1000);
 | |
| EXPECTED select 0.99 - 1/500*0.99 * 1/500*0.99*2;
 | |
| select c1 from t1 where (c1,c2) not in ((500, 8000), (8000, 10000));
 | |
| #BTW, NOT BTW
 | |
| select 1/500*0.99*5;
 | |
| select c1 from t1 where c1 between 1000 and 10000;
 | |
| select 0.4;
 | |
| select c1 from t1 where c1 not between 1000 and 10000;
 | |
| select 1/500*0.99;
 | |
| select c1 from t1 where c1 between 1000 and 1000;
 | |
| select 0.4;
 | |
| select c1 from t1 where c1 not between 1000 and 1000;
 | |
| select 0;
 | |
| select c1 from t1 where c1 between 10000 and 1000;
 | |
| select 0.4;
 | |
| select c1 from t1 where c1 not between 10000 and 1000;
 | |
| select 0;
 | |
| select c1 from t1 where c1 >= 10000 and c1<=1000;
 | |
| select 0.2;
 | |
| select c1 from t1 where 1000 between c1 and 1000;
 | |
| select 0.2;
 | |
| select c1 from t1 where 1000 not between c1 and 1000;
 | |
| select 0;
 | |
| select c1 from t1 where 1000 between 10000 and c1;
 | |
| select 0.2;
 | |
| select c1 from t1 where 2000 between 1000 and c1;
 | |
| select 1;
 | |
| select c1 from t1 where 1 between 0 and 1;
 | |
| select 0;
 | |
| select c1 from t1 where 100 between 0 and 1;
 | |
| #JOIN COND
 | |
| # min(basic_sel1, basic_sel2)
 | |
| select 1/500*0.99;
 | |
| select t1.c1 from t1,t2 where t1.c1 = t2.c1;
 | |
| select 1/500*0.99;
 | |
| select t1.c1 from t1,t2 where t1.c1 + 1 = t2.c1;
 | |
| select 1/500*0.99;
 | |
| select t1.c1 from t1,t2 where t1.c1 + 1 = t2.c1 + 1;
 | |
| select 1/500*0.99;
 | |
| select t1.c1 from t1,t2 where t1.c1 * 2 = t2.c1 + 1;
 | |
| select 1/500*0.99;
 | |
| select t1.c1 from t1,t2 where t1.c1 / 2 = t2.c1 + 1;
 | |
| select 1/500*0.99 * (1/3);
 | |
| select t1.c1 from t1,t2 where t1.c1 = t2.c1 and t1.c2 > t2.c2;
 | |
| select 1/3;
 | |
| select t1.c1 from t1, t2 where t1.c1 < t2.c2;
 | |
| select 0.5;
 | |
| select t1.c1 from t1, t2 where t1.c1 != t2.c2;
 | |
| # IS_WITH_SUBQUERY
 | |
| select 1/500*0.99
 | |
| select c1 from t1 where c1 = (select c2 from t1 where c2 >= 10000);
 | |
| select 1.0 / 3.0 DEFAULT_INEQ_SEL
 | |
| select c1 from t1 where c1 > (select c2 from t1 where c2 >= 10000);
 | |
| todo. 1- 1/500*0.99 - 0.01
 | |
| select c1 from t1 where c1 != (select c2 from t1 where c2 >= 10000);
 | |
| todo. DEFAULT_SEL
 | |
| select c1 from t1 where c1 in (select c2 from t1 where c2 = 10000);
 | |
| todo. DEFAULT_SEL
 | |
| select c1 from t1 where c1 = ANY (select c2 from t1 where c2 > 1000);
 | |
| todo. DEFAULT_SEL
 | |
| select c1 from t1 where c1 != ANY (select c2 from t1 where c2 > 1000);
 | |
| todo. DEFAULT_SEL
 | |
| select c1 from t1 where c1 = SOME (select c2 from t1 where c2 > 1000);
 | |
| todo. DEFAULT_SEL
 | |
| select c1 from t1 where c1 != SOME (select c2 from t1 where c2 > 1000);
 | |
| todo. DEFAULT_SEL
 | |
| select c1 from t1 where c1 = ALL (select c2 from t1 where c2 > 1000);
 | |
| todo. DEFAULT_SEL
 | |
| select c1 from t1 where c1 != ALL (select c2 from t1 where c2 > 1000);
 | |
| #ROW
 | |
| select 1/500 * 0.99 * (1/500 * 0.99)
 | |
| select c1 from t1 where (c1, c2) = (2000, 10000);
 | |
| todo. 0.5
 | |
| select c1 from t1 where (c1, c2) != (2000, 10000);
 | |
| select 0.2
 | |
| select c1 from t1 where (c1, c2) > (2000, 10000);
 | 
