VastbaseG100

基于openGauss内核开发的企业级关系型数据库。

Menu

同层参数化路径的Hint

功能描述

通过predpush_same_level Hint来指定同层表或物化视图之间参数化路径生成。

语法格式

predpush_same_level(src, dest)
predpush_same_level(src1 src2 ..., dest)

本参数仅在rewrite_rule中的predpushforce选项打开时生效。

参数说明

  • srcN

    指定的路径源。

    • predpush_same_level可以指定多个src,但是所有的src必须在同一个条件中。

    • 如果指定的src和dest条件不存在,或该条件不符合参数化路径要求,则本hint不生效。

  • dest

    指定的路径目标。

示例

1、准备参数和表及索引:

set rewrite_rule = 'predpushforce';
create table t1(a int, b int);
create table t2(a int, b int);
create index idx1 on t1(a);
create index idx2 on t2(a);

返回结果为如下:

SET
CREATE TABLE
CREATE TABLE
CREATE INDEX
CREATE INDEX

2、执行语句查看计划:

explain select * from t1, t2 where t1.a = t2.a;

结果显示为如下:

                            QUERY PLAN
------------------------------------------------------------------
 Hash Join  (cost=27.50..56.25 rows=1000 width=16)
   Hash Cond: (t1.a = t2.a)
   ->  Seq Scan on t1  (cost=0.00..15.00 rows=1000 width=8)
   ->  Hash  (cost=15.00..15.00 rows=1000 width=8)
         ->  Seq Scan on t2  (cost=0.00..15.00 rows=1000 width=8)
(5 rows)

3、通过步骤2可以看到t1.a = t2.a条件过滤在Join上面,此时可以通过predpush_same_level(t1, t2)将条件下推至t2的扫描算子上:

explain select /*+predpush_same_level(t1, t2)*/ * from t1, t2 where t1.a = t2.a;

结果显示为如下:

                             QUERY PLAN
---------------------------------------------------------------------
 Nested Loop  (cost=0.00..335.00 rows=1000 width=16)
   ->  Seq Scan on t1  (cost=0.00..15.00 rows=1000 width=8)
   ->  Index Scan using idx2 on t2  (cost=0.00..0.31 rows=1 width=8)
         Index Cond: (a = t1.a)
(4 rows)
  • predpush_same_level可以指定多个src,但是所有的src必须在同一个条件中。
  • 如果指定的src和dest条件不存在,或该条件不符合参数化路径要求,则本hint不生效。