指定是否使用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对分区表进行并发扫描。
partitionwisescan只支持SMP场景下的分区表的扫描,支持SeqScan、IndexScan、IndexonlyScan、ImcvScan。
示例
--创建分区表。
gaussdb=# CREATE TABLE HASH_PART
(
a INTEGER,
b INTEGER,
c INTEGER
) PARTITION BY HASH(a) (
PARTITION p1,
PARTITION p2,
PARTITION p3
);
CREATE TABLE
--开启SMP和Partition-wise Join。
gaussdb=# SET query_dop = 5;
SET
gaussdb=# SET enable_smp_partitionwise = on;
SET
gaussdb=# SET enable_force_smp = on;
SET
--使用partitionwisescan的hint。
gaussdb=# EXPLAIN (COSTS OFF) SELECT /*+ partitionwisescan(HASH_PART)*/ count(*) FROM HASH_PART;
QUERY PLAN
-----------------------------------------------------------
Aggregate
-> Streaming(type: LOCAL GATHER dop: 1/5)
-> Aggregate
-> Partition Iterator
Iterations: 3
-> Partitioned Seq Scan on hash_part
Selected Partitions: 1..3
(7 rows)
-- 删除分区表
gaussdb=# DROP TABLE HASH_PART;