blob: 6d39525d41847c19a0359270b5265677c4aaeca8 [file] [log] [blame]
-- Regression tests for prepareable statements
-- Force a generic plan to specifically test parameters
set plan_cache_mode=force_generic_plan;
SET optimizer_trace_fallback to on;
create schema qp_query_params;
set search_path=qp_query_params;
create table t1 (a int, b int);
insert into t1 select i, i from generate_series(1,4)i;
analyze t1;
create table t2(a int, b int);
insert into t2 values (1,1);
analyze t2;
CREATE TABLE part (
a int ,
b int,
c text,
d numeric)
DISTRIBUTED BY (b)
partition by range(a) (
start(1) end(6) every(2),
default partition def);
insert into part select i,i,'abc',i*1.01 from generate_series(1,10)i;
analyze part;
-- Should simplify to false, Orca does not
PREPARE q1 as SELECT * from t1 where a=$1 and a!=$1;
explain (costs off) execute q1(3);
execute q1(3);
deallocate q1;
-- Should simplify to false, currently does not
PREPARE q1 as SELECT * from t1 where $1!=$1;
explain (costs off) execute q1(4);
execute q1(4);
deallocate q1;
-- Should perform static elimination at execution time, Orca does not do this currently
PREPARE q1 as SELECT * from part where a=$1;
explain (costs off) EXECUTE q1(2);
execute q1(2);
-- Ensure default partition is scanned
explain (costs off) EXECUTE q1(9);
execute q1(9);
deallocate q1;
-- Test multiple query params
PREPARE q1 as SELECT * from t1 where a=$1 and b=$2;
explain (costs off) execute q1(4,4);
execute q1(4,4);
deallocate q1;
-- Test param op param
PREPARE q1 as SELECT * from t1 where $1=$2;
explain (costs off) execute q1(4,5);
execute q1(4,5);
deallocate q1;
-- Should NOT produce a direct dispatch plan!
PREPARE q1 as SELECT * from t1 where a=$1;
explain (costs off) execute q1(5);
execute q1(5);
deallocate q1;
-- Should NOT do direct dispatch with delete. Explain doesn't show this, so we must verify results
PREPARE q1 as DELETE from t1 where a=$1;
explain (costs off) execute q1(1);
execute q1(1);
deallocate q1;
select count(*) from t1;
-- Should NOT do direct dispatch with insert. Explain doesn't show this, so we must verify results
PREPARE q1 as INSERT into t1 values ($1, $2);
explain (costs off) execute q1(1,3);
execute q1(1,3);
deallocate q1;
select count(*) from t1;
-- Test index with parameter
CREATE INDEX idx on t1(b);
PREPARE q1 as select * from t1 where b=$1;
explain (costs off) execute q1(3);
execute q1(3);
deallocate q1;
drop index idx;
-- Test limit with parameter
PREPARE q1 as select * from t1 order by a limit $1;
explain (costs off) execute q1(4);
execute q1(4);
deallocate q1;
-- Test normalization with params
PREPARE q1 as select count(*)+$1+$2 from t1 group by t1.a;
explain (verbose, costs off) execute q1(4,1);
execute q1(4,1);
deallocate q1;
PREPARE q1 as select count(*)+$1+$2 from t1 group by t1.a+$2;
explain (verbose, costs off) execute q1(3,2);
execute q1(3,2);
deallocate q1;
PREPARE q1 as select sum(b)+$1 from t1 group by(b) having count(*) > $2;
explain (verbose, costs off) execute q1(4,0);
execute q1(4,0);
deallocate q1;
-- Test subplans with params
PREPARE q1 as select $1::int, (select b from t2 where b=t1.a and b!=$1) from t1;
explain (verbose, costs off) execute q1(4);
execute q1(4);
deallocate q1;