更新时间:2024-11-12 GMT+08:00
分享

指定是否使用partition-wise scan优化的hint

在SMP场景下,对于分区表的并发扫描方式分为两种:

  • 每个线程会遍历所有分区,但是只读取分区的一部分数据,线程之间读取的数据没有交集,所有线程读取的数据合并后是分区的全部数据。
  • 每个线程只和一部分分区绑定,线程之间绑定的分区没有交集,线程读取绑定分区的所有数据,该方式称为Partition-wise Scan。

在一些场景下,Partition-wise Scan能够更均匀地读取数据,具有更高的并发读取性能。

开启Partition-wise Scan的方式有如下两种:

  • 设置GUC参数force_smp_partitionwise_scan。
  • 设置partitionwisescan的hint。

功能描述

在SMP场景下,指定语句是否对分区表使用Partition-wise Scan。

语法格式

[no] partitionwisescan[(@tablename)]

参数说明

  • no

    不使用Partition-wise Scan查询改写。

  • @tablename

    进行Partition-wise Scan的分区表,不可省略。

  • partitionwisescan

    使用Partition-wise Scan对分区表进行并发扫描。

示例

--创建分区表。
gaussdb=# CREATE TABLE partition_3_part
(
    a INTEGER,
    b INTEGER,
    c INTEGER
) PARTITION BY HASH(a) (
    PARTITION p1,
    PARTITION p2,
    PARTITION p3
);

--开启SMP和Partition-wise Join。
gaussdb=# SET query_dop = 5;
SET
gaussdb=# SET enable_smp_partitionwise = on;
SET

--使用partitionwisescan的hint。
gaussdb=# EXPLAIN SELECT /*+ partitionwisescan(partition_3_part)*/ count(*) FROM partition_3_part;
                                              QUERY PLAN                                              
------------------------------------------------------------------------------------------------------
 Aggregate  (cost=14.24..14.31 rows=1 width=8)
   ->  Streaming (type: GATHER)  (cost=14.24..14.31 rows=3 width=8)
         Node/s: All datanodes
         ->  Aggregate  (cost=14.18..14.19 rows=3 width=8)
               ->  Partition Iterator  (cost=0.00..14.14 rows=30 width=0)
                     Iterations: 3
                     ->  Partitioned Seq Scan on partition_3_part  (cost=0.00..14.14 rows=30 width=0)
                           Selected Partitions:  1..3
(8 rows)

-- 删除分区表
gaussdb=# DROP TABLE partition_3_part;

相关文档