MergeAppend
Description
MergeAppend is used to append multiple ordered relationship sets. The operation is similar to Append. The only difference is that MergeAppend accelerates the calculation of ordered relationship sets. MergeAppend merges subquery results in a way that preserves the sort order. It can be used to merge sorted rows in a table partition. Therefore, different from common Append, MergeAppend needs to ensure that the input m_plan is ordered before performing operations. Generally, a sort operator appears before the MergeAppend operation (that is, in the subtree of the execution plan).
Typical Scenarios
The partition scan path is index or index-only, the partition pruning result is greater than 1, and the following conditions are met:
All partition indexes are valid B-tree indexes. The SQL query contains the LIMIT clause. During partition scan, no partitioned table query statement with the filter exists.
The MergeAppend path is no longer generated when the GUC parameter sql_beta_feature is set to 'disable_merge_append_partition'.
Examples
-- Prepare data. gaussdb=# CREATE TABLE test_range_pt (a INT, b INT, c INT) PARTITION BY RANGE(a) ( PARTITION p1 VALUES LESS THAN (2000), PARTITION p2 VALUES LESS THAN (3000), PARTITION p3 VALUES LESS THAN (4000), PARTITION p4 VALUES LESS THAN (5000), PARTITION p5 VALUES LESS THAN (MAXVALUE) )ENABLE ROW MOVEMENT; CREATE TABLE gaussdb=# INSERT INTO test_range_pt VALUES (generate_series(1,10000),generate_series(1,10000),generate_series(1,10000)); INSERT 0 10000 gaussdb=# CREATE INDEX idx_range_b ON test_range_pt(b) LOCAL; CREATE INDEX gaussdb=# ANALYZE test_range_pt; ANALYZE -- Execution result. gaussdb=# EXPLAIN ANALYZE SELECT * FROM test_range_pt WHERE b >10 AND b < 5000 ORDER BY b LIMIT 10; QUERY PLAN -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- Limit (cost=153.32..153.49 rows=10 width=12) (actual time=9.131..9.138 rows=10 loops=1) -> Streaming (type: GATHER) (cost=153.32..153.66 rows=10 width=12) (actual time=9.127..9.130 rows=10 loops=1) Merge Sort Key: b Node/s: All datanodes -> Limit (cost=152.70..152.72 rows=20 width=12) (actual time=[4.777,4.782]..[4.899,4.903], rows=20) -> Sort (cost=152.70..158.94 rows=20 width=12) (actual time=[4.774,4.776]..[4.897,4.899], rows=20) Sort Key: b Sort Method: top-N heapsort Memory: 26kB ~ 26kB -> Partition Iterator (cost=0.00..98.76 rows=4991 width=12) (actual time=[0.164,3.639]..[0.179,3.743], rows=4989) Iterations: 5 -> Partitioned Index Scan using idx_range_b on test_range_pt (cost=0.00..98.76 rows=4991 width=12) (actual time=[0.522,2.923]..[0.602,2.980], rows=4989) Index Cond: ((b > 10) AND (b < 5000)) Selected Partitions: 1..5 Total runtime: 10.534 ms (14 rows) -- Drop. gaussdb=# DROP TABLE test_range_pt;
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.
 
    