120 lines
5.2 KiB
SQL
120 lines
5.2 KiB
SQL
################################## Index Hint ##################################
|
|
#测试主键index和普通index的情况
|
|
select /*+FULL(t4)*/* from t4;
|
|
select /*+INDEX(t4 idx_t4_c2_c3)*/* from t4;
|
|
select /*+INDEX(t4 idx_t4_c2)*/* from t4;
|
|
select /*+INDEX(t4 idx_t4_c3)*/* from t4;
|
|
select /*+INDEX(t_pt t_pt_idx_1)*/* from t_pt where (c2,c1) > (300,200);
|
|
select /*+INDEX(t_pt primary)*/* from t_pt where (c2,c1) > (300,200);
|
|
select /*+INDEX(t_pt primary)*/* from t_pt where (c1,c2) > (200,300);
|
|
|
|
#测试无效index的情况
|
|
select /*+INDEX(t4 idx_t4_invalid)*/* from t4;
|
|
|
|
#测试同一个table 对应多个可选index
|
|
select /*+INDEX(t4 idx_t4_c3) INDEX(t4 idx_t4_c2) INDEX(t4 idx_t4_c2_c3) */* from t4;
|
|
select * from t4 use index(idx_t4_c3, idx_t4_c2, idx_t4_c2_c3);
|
|
select * from t4 force index(idx_t4_c3, idx_t4_c2, idx_t4_c2_c3);
|
|
select /*+INDEX(t4 idx_t4_c3) FULL(t4) */* from t4;
|
|
|
|
#测试指定多个table index的情况
|
|
select /*+INDEX(t4 idx_t4_c3) INDEX(t5 idx_t5_c2)*/* from t4,t5;
|
|
|
|
#测试alias的情况
|
|
select /*+INDEX(t4 idx_t4_c3)*/* from t4 as tt;
|
|
select /*+INDEX(tt idx_t4_c3)*/* from t4 as tt;
|
|
|
|
#测试index list为空的情况
|
|
select * from t4 use index();
|
|
|
|
#测试use_index与ignore_index混用的情况
|
|
select /*+INDEX(t4 idx_t4_c3) */* from t4 ignore index(idx_t4_c3);
|
|
|
|
##### 测试ingore的情况#####
|
|
select * from t4 ignore index(idx_t4_c3);
|
|
select * from t4 ignore index(idx_t4_c2);
|
|
|
|
# 同时制定多个ingore, 当同时编写多个ingore时,只有第一个生效
|
|
select * from t4 ignore index(idx_t4_c3, idx_t4_c2);
|
|
select * from t4 ignore index(idx_t4_c3) ignore index(idx_t4_c2);
|
|
|
|
# alias
|
|
select * from t4 tt ignore index(idx_t4_c3, idx_t4_c2);
|
|
select * from t4 tt ignore index(idx_t4_c3) ignore index(idx_t4_c2);
|
|
|
|
# primary
|
|
select * from t4 tt ignore index(primary, idx_t4_c2);
|
|
select * from t4 tt ignore index(primary) ignore index(idx_t4_c3);
|
|
select * from t4 tt ignore index(primary) ignore index(idx_t4_c2_);
|
|
|
|
|
|
################################## Join Type Hint ##################################
|
|
|
|
# normal
|
|
select * from t4,t5;
|
|
select /*+leading(t4 t5) use_nl(t5)*/* from t4,t5;
|
|
|
|
# alias
|
|
select /*+leading(tt4 tt5) use_nl(tt5)*/* from t4 tt4, t5 tt5;
|
|
|
|
# multi hint
|
|
select /*+leading (t4 t5) use_nl(t5) use_nl(t5) use_nl(t5)*/* from t4,t5;
|
|
select /*+use_nl(t4) use_nl(t5)*/* from t4,t5;
|
|
|
|
# outer join
|
|
select /*+leading (t4 t5) use_nl(t5)*/* from t4 left join t5 on t4.c1 = t5.c1;
|
|
select /*+leading (t5 t4) use_nl(t5)*/* from t4 left join t5 on t4.c1 = t5.c1;
|
|
select /*+leading (t4 t5) use_nl(t5)*/* from t4 right join t5 on t4.c1 = t5.c1;
|
|
select /*+leading (t5 t4) use_nl(t5)*/* from t4 right join t5 on t4.c1 = t5.c1;
|
|
select /*+leading (t4 t5) use_nl(t5)*/* from t4 full join t5 on t4.c1 = t5.c1;
|
|
select /*+leading (t5 t4) use_nl(t5)*/* from t4 full join t5 on t4.c1 = t5.c1;
|
|
select /*+leading (t4 t5) use_merge(t5)*/* from t4 left join t5 on t4.c1 = t5.c1;
|
|
select /*+leading (t4 t5) use_merge(t5)*/* from t4 right join t5 on t4.c1 = t5.c1;
|
|
select /*+leading (t4 t5) use_merge(t5)*/* from t4 full join t5 on t4.c1 = t5.c1;
|
|
|
|
# subplan_scan
|
|
select /*+leading(tt t5) use_nl(t5)*/* from (select max(c1) from t1) tt, t5;
|
|
select /*+leading(t5 tt) use_nl(tt)*/* from (select max(c1) from t1) tt, t5;
|
|
|
|
# test for different join type
|
|
select /*+leading(t4 t5) use_bnl(t5)*/* from t4,t5;
|
|
select /*+leading(t4 t5) use_bnl(t5)*/* from t4,t5;
|
|
|
|
# multi join tree
|
|
select /*+leading(tt t5) use_nl(t5)*/* from (select /*+leading(t4 t7) use_nl(t7)*/max(t4.c1) from t4,t7) tt, t5;
|
|
select /*+leading(t5 tt) use_nl(tt)*/* from (select /*+leading(t7 t4) use_nl(t4)*/max(t4.c1) from t4,t7) tt, t5;
|
|
|
|
# test for leading
|
|
select /*+ordered*/* from t4,t5;
|
|
select /*+ordered*/* from t5,t4;
|
|
select /*+ordered*/* from t5;
|
|
select /*+ordered*/* from t4 left join t5 on t4.c1=t5.c1;
|
|
select /*+ordered*/* from t4 right join t5 on t4.c1=t5.c1;
|
|
select /*+ordered*/* from t4 full join t5 on t4.c1=t5.c1;
|
|
|
|
################################## test for late materialization ##################################
|
|
select /*+index(t_normal_idx idx)*/* from t_normal_idx order by c3 limit 1;
|
|
select /*+use_late_materialization index(t_normal_idx idx)*/* from t_normal_idx order by c3 limit 1;
|
|
select /*+no_use_late_materialization index(t_normal_idx idx)*/* from t_normal_idx where c2=1 order by c4 limit 1;
|
|
|
|
################################## test for qb_name ##################################
|
|
select * from t4;
|
|
select /*+qb_name(select_1)*/* from t4;
|
|
select /*+qb_name(select_1) qb_name(select_2)*/* from t4;
|
|
select /*+qb_name(select_1) */* from t4 where t4.c1 > any(select /*+qb_name(select_2)*/c1 from t5);
|
|
select /*+qb_name(select_1) */* from t4 where t4.c1 > any(select /*+qb_name(select_1)*/c1 from t5);
|
|
|
|
################################## 测试不应该显示的hint ##################################
|
|
select /*+topk(1 100) hotspot max_concurrent(1)*/* from t4;
|
|
|
|
################################## 测试指定即生效的hint #################################
|
|
select /*+read_consistency("weak")*/* from t1;
|
|
select /*+query_timeout(100)*/ * from t1;
|
|
select /*+frozen_version(1)*/ * from t1;
|
|
select /*+use_plan_cache(none)*/ * from t1;
|
|
select /*+use_plan_cache(default)*/ * from t1;
|
|
select /*+use_plan_cache(nothing)*/ * from t1;
|
|
select /*+no_rewrite*/ * from t1;
|
|
select /*+trace_log*/ * from t1;
|
|
select /*+log_level('INFO')*/ * from t1;
|