Temporary partition
A temporary partition belongs to a partitioned table. Only partitioned tables can create temporary partitions.
- The partition columns of the temporary partition is the same as the formal partition and cannot be modified.
- The partition ranges of all temporary partitions of a table cannot overlap, but the ranges of temporary partitions and formal partitions can overlap.
- The partition name of the temporary partition cannot be the same as the formal partitions and other temporary partitions.
The temporary partition supports add, delete, and replace operations.
You can add temporary partitions to a table with the statement:
See HELP ALTER TABLE;
for more help and examples.
Some instructions for adding operations:
- Adding a temporary partition is similar to adding a formal partition. The partition range of the temporary partition is independent of the formal partition.
- Temporary partition can independently specify some attributes. Includes information such as the number of buckets, the number of replicas, whether it is a memory table, or the storage medium.
Delete temporary partition
A table’s temporary partition can be dropped with the ALTER TABLE DROP TEMPORARY PARTITION
statement:
ALTER TABLE tbl1 DROP TEMPORARY PARTITION tp1;
See HELP ALTER TABLE;
for more help and examples.
Some instructions for the delete operation:
- Deleting the temporary partition will not affect the data of the formal partition.
You can replace formal partitions of a table with temporary partitions with the ALTER TABLE REPLACE PARTITION
statement.
ALTER TABLE tbl1 REPLACE PARTITION (p1) WITH TEMPORARY PARTITION (tp1);
ALTER TABLE tbl1 REPLACE PARTITION (p1, p2) WITH TEMPORARY PARTITION (tp1, tp2, tp3);
ALTER TABLE tbl1 REPLACE PARTITION (p1, p2) WITH TEMPORARY PARTITION (tp1, tp2)
PROPERTIES (
"strict_range" = "false",
"use_temp_partition_name" = "true"
See HELP ALTER TABLE;
for more help and examples.
The replace operation has two special optional parameters:
strict_range
The default is true.
For Range partition, When this parameter is true, the range union of all formal partitions to be replaced needs to be the same as the range union of the temporary partitions to be replaced. When set to false, you only need to ensure that the range between the new formal partitions does not overlap after replacement.
For List partition, this parameter is always true, and the enumeration values of all full partitions to be replaced must be identical to the enumeration values of the temporary partitions to be replaced.
Here are some examples:
-
Range of partitions p1, p2, p3 to be replaced (=> union):
(10, 20), [20, 30), [40, 50) => [10, 30), [40, 50)
Replace the range of partitions tp1, tp2 (=> union):
(10, 30), [40, 45), [45, 50) => [10, 30), [40, 50)
The union of ranges is the same, so you can use tp1 and tp2 to replace p1, p2, p3.
Example 2
Range of partition p1 to be replaced (=> union):
(10, 50) => [10, 50)
Replace the range of partitions tp1, tp2 (=> union):
The union of ranges is not the same. If
strict_range
is true, you cannot use tp1 and tp2 to replace p1. If false, and the two partition ranges[10, 30), [40, 50)
and the other formal partitions do not overlap, they can be replaced.Example 3
Enumerated values of partitions p1, p2 to be replaced (=> union).
Replace the enumerated values of partitions tp1, tp2, tp3 (=> union).
(1, 2, 3), (4), (5, 6) => (1, 2, 3, 4, 5, 6)
The enumeration values are the same, you can use tp1, tp2, tp3 to replace p1, p2
Example 4
Enumerated values of partitions p1, p2, p3 to be replaced (=> union).
(("1", "beijing"), ("1", "shanghai")), (("2", "beijing"), ("2", "shanghai")), (("3", "beijing"), ("3", "shanghai")) => (("1", "beijing"), ("3", "shanghai")) "), ("1", "shanghai"), ("2", "beijing"), ("2", "shanghai"), ("3", "beijing"), ("3", "shanghai"))
Replace the enumerated values of partitions tp1, tp2 (=> union).
(("1", "beijing"), ("1", "shanghai")), (("2", "beijing"), ("2", "shanghai"), ("3", "beijing"), ("3", "shanghai")) => (("1", "beijing") , ("1", "shanghai"), ("2", "beijing"), ("2", "shanghai"), ("3", "beijing"), ("3", "shanghai"))
The enumeration values are the same, you can use tp1, tp2 to replace p1, p2, p3
-
use_temp_partition_name
Example 1
ALTER TABLE tbl1 REPLACE PARTITION (p1) WITH TEMPORARY PARTITION (tp1);
use_temp_partition_name
is false by default. After replacement, the partition name is still p1, but the related data and attributes are replaced with tp1.If
use_temp_partition_name
is true by default, the name of the partition is tp1 after replacement. The p1 partition no longer exists.Example 2
use_temp_partition_name
is false by default, but this parameter is invalid because the number of partitions to be replaced and the number of replacement partitions are different. After the replacement, the partition name is tp1, and p1 and p2 no longer exist.
Some instructions for the replacement operation:
- After the partition is replaced successfully, the replaced partition will be deleted and cannot be recovered.
Users can load data into temporary partitions or specify temporary partitions for querying.
Load temporary partition
The syntax for specifying a temporary partition is slightly different depending on the load method. Here is a simple illustration through an example:
INSERT INTO tbl TEMPORARY PARTITION (tp1, tp2, ...) SELECT ....
curl --location-trusted -u root: -H "label: 123" -H "temporary_partition: tp1, tp2, ..." -T testData http: // host: port / api / testDb / testTbl / _stream_load
LOAD LABEL example_db.label1
(
DATA INFILE ("hdfs: // hdfs_host: hdfs_port / user / palo / data / input / file")
INTO TABLE `my_table`
TEMPORARY PARTITION (tp1, tp2, ...)
...
WITH BROKER hdfs ("username" = "hdfs_user", "password" = "hdfs_password");
CREATE ROUTINE LOAD example_db.test1 ON example_tbl
COLUMNS (k1, k2, k3, v1, v2, v3 = k1 * 100),
TEMPORARY PARTITIONS (tp1, tp2, ...),
PROPERTIES
(...)
FROM KAFKA
(...);
Query the temporary partition
SELECT ... FROM
tbl1 TEMPORARY PARTITION (tp1, tp2, ...)
JOIN
tbl2 TEMPORARY PARTITION (tp1, tp2, ...)
ON ...
WHERE ...;
DROP
- After using the
DROP
operation to directly drop the database or table, you can recover the database or table (within a limited time) through theRECOVER
command, but the temporary partition will not be recovered. - After the formal partition is dropped using the
ALTER
command, the partition can be recovered by theRECOVER
command (within a limited time). Operating a formal partition is not related to a temporary partition. - After the temporary partition is dropped using the
ALTER
command, the temporary partition cannot be recovered through theRECOVER
command.
- Use the
TRUNCATE
command to empty the table. The temporary partition of the table will be deleted and cannot be recovered. - When using
TRUNCATE
command to empty the formal partition, it will not affect the temporary partition. - You cannot use the
TRUNCATE
command to empty the temporary partition.
ALTER
- When the table has a temporary partition, you cannot use the
ALTER
command to perform Schema Change, Rollup, etc. on the table. - You cannot add temporary partitions to a table while the table is undergoing a alter operation.
Atomic overwrite
In some cases, the user wants to be able to rewrite the data of a certain partition, but if it is dropped first and then loaded, there will be a period of time when the data cannot be seen. At this moment, the user can first create a corresponding temporary partition, load new data into the temporary partition, and then replace the original partition atomically through the
REPLACE
operation to achieve the purpose. For atomic overwrite operations of non-partitioned tables, please refer toModify the number of buckets
In some cases, the user used an inappropriate number of buckets when creating a partition. The user can first create a temporary partition corresponding to the partition range and specify a new number of buckets. Then use the command to load the data of the formal partition into the temporary partition. Through the replacement operation, the original partition is replaced atomically to achieve the purpose.